Automatic correction for The Bridge Exercises
Project description
The Bridge Coding Problems Autochecker (CPA)
graph TD;
Check?--yes-->TypeOfProblem?;
Check?--no-->ThoughtProblem;
ThoughtProblem-->hints;
ThoughtProblem-->solution;
TypeOfProblem?-->EqualityCheckProblem;
EqualityCheckProblem-->Expected;
EqualityCheckProblem-->Check;
EqualityCheckProblem-->Hints;
EqualityCheckProblem-->Solution;
EqualityCheckProblem-->Vars;
TypeOfProblem?-->FunctionProblem;
FunctionProblem-->Vars;
FunctionProblem-->TestCases;
FunctionProblem-->Hints;
FunctionProblem-->Solution;
FunctionProblem-->Check;
TypeOfProblem?-->Other;
Other-->CodingProblem;
Steps for PyPI publishing
- Create a package folder (
learntools
) containing separated modules (e.g.core
,python
, ...). - Each module contains the solutions for each of the problems. We can separate the problems in different blocks. For example, one for
Python Basics
, another one forpandas
and so on. - The next file is
__init__.py
. The double underscores in the filename tell you that this is a special file.__init__.py
represents the root of each package. It should usually be kept quite simple, but it’s a good place to put package constants, documentation, ...- Inside init we export modules so that, calling
from learntools.core import *
we can have access to that modules, e.g.binder
without doing,learntools.core..globals_binder.binder
.
- Inside init we export modules so that, calling
- In
notebooks
folder we are going to test the modules. TODO: Introduce testing files and introduce them in a test folder. - Each Python project should use a file named
pyproject.toml
to specify its build system. In this case, the one specified is setuptools as a build system as well as which dependencies Python must install in order to build your package. Typically, the documentation of your chosen build system will tell you how to write the build-system table in pyproject.toml. - The more interesting information that you need to provide concerns your package itself. PEP 621 defines how metadata about your package can also be included in pyproject.toml in a way that’s as uniform as possible across different build systems.
- Update version:
bumpver update [--major | --minor | --patch]
- Generate wheel and source files inside
dist
folderpython –m build
- Update dependencies in
pyproject.toml
and in this README - Update the Changelog
- Publish the package
twine upload dist/*
- Update the tag on Git and push the commit
git tag vx.y.z
Dependencies tracking
[07/09/22] core: [pandas
]
[v1.1.0] problem_view: [ipywidgets
]
Next Steps
- Introduce testing files and introduce them in a test folder
- Fill LICENSE file
- Make it pretty (KISS: Keep It Simple Stupid)
- Hints monitoring in order to get indsights of student's development
Changelog
1.1.0
- Try to add buttons using, for example,
ipywidgets
[#DONE in v1.1.0]- The code can be optimized playing with @display and creating a decorator for the buttons [TODO][problem_view.py]
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
thebridge-autocheck-1.1.1.tar.gz
(39.8 kB
view details)
Built Distribution
File details
Details for the file thebridge-autocheck-1.1.1.tar.gz
.
File metadata
- Download URL: thebridge-autocheck-1.1.1.tar.gz
- Upload date:
- Size: 39.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ca320d822e831e418315cb62acd888b3028331d83790558cfa7aa24542383c86 |
|
MD5 | 5494f15bfbead27dbaa00b78bca43913 |
|
BLAKE2b-256 | 4faad832b013e12656024257ed69dc0fd75b21ebf7122068fb272ca7ee96d725 |
File details
Details for the file thebridge_autocheck-1.1.1-py3-none-any.whl
.
File metadata
- Download URL: thebridge_autocheck-1.1.1-py3-none-any.whl
- Upload date:
- Size: 50.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ef4aaa4f3c300e495a7688e92673b0df3e0243cd0b560f9129e31023f7b267c1 |
|
MD5 | 6343844cbac5e54f4b7d9803b9020f97 |
|
BLAKE2b-256 | 131e4ab427c7fed8368d0440c81f6ab13a68fd3f1d110871d500d49a3c155f23 |