toolkit to works on cubicweb cubes
Project description
CubeToolkit
CubeToolkit is a CLI toolkit to help with the development of [CubicWeb](https://www.cubicweb.org/)’s cubes. The idea is to put mostly all tools and scripts in the same place.
Installation
pip install –user cubetoolkit
Available tools
generate-pyramid-ini
This tool generates the needed pyramid.ini file for instances using secure random generated secrets.
Usage:
# this will print the generated file on the standard output cubetoolkit generate-pyramid-ini
# this will put the file in the instance folder if not present cubetoolkit generate-pyramid-ini –instance instanceName # or cubetoolkit generate-pyramid-ini -i instanceName
# this will in addition overwrite an existing pyramid.ini file cubetoolkit generate-pyramid-ini –instance instanceName -f
autoupgradedependencies
This tool is meant to upgrades the dependencies of a CubicWeb cube by parsing its __pkginfo__.py and trying to upgrade each of its dependencies one by one and running tests in the middle.
The algorithm is the following one:
find __pkginfo__.py either in the root of the project or in cubicweb_{project_name}
parse it, extract the values of __depends__
merge those informations with pypi’s one
only keep the packages that can be upgraded
- for all upgradables cubes:
try to upgrade to the latest version
check if the cube has changed to a new-style cube
if so update the imports
- run tests (a command provided by the user)
if the tests successed, commit
else, redo the previous step but next upgradable version by next upgradable version until you find the first buggy one, in the case the previous one is the good one, commit it
redo the same operations for dependencies that aren’t cube without the upgrade part
display of summary of what has been done and which upgrades failed and point to their tests logs
exit
Usage:
In the folder where the .hg is in a classic cube.
cubetoolkit autoupgradedependencies “test command”
Examples:
cubetoolkit autoupgradedependencies “tox -e py27 –recreate” cubetoolkit autoupgradedependencies “py.test tests”
generate-doc
This tool will generate a base documentation for a cube using sphinx-apidoc to expose the module content in the doc.
Only works for new-style cube.
Usage:
# in the same directory that the cubicweb_$cube directory cubetoolkit generate-doc
to-newstyle-cube
This tool by nsukami will do /most/ of the work to migrate a cube in the oldstyle format to the new one.
Usage:
cubetoolkit to-newstyle-cube /path/to/cube
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
Built Distribution
File details
Details for the file cubetoolkit-0.3.1.tar.gz
.
File metadata
- Download URL: cubetoolkit-0.3.1.tar.gz
- Upload date:
- Size: 9.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/2.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e5032d3186ee620581b77204f93c29543a67e93c9d57842c86993f5a9d17795a |
|
MD5 | 4569622e73ac1d89cc121d464b8db93b |
|
BLAKE2b-256 | 412891cbc72643f96e1c4017068b391f49c7040c84792a438387594d8a881549 |
File details
Details for the file cubetoolkit-0.3.1-py2-none-any.whl
.
File metadata
- Download URL: cubetoolkit-0.3.1-py2-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/2.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d4f218dfdd3b1d9b039a5ced07c3ffeb08f24f0fa45a92a5795a8d2c1b9b1f58 |
|
MD5 | 6864e50c17126e71d71af0f0b120deb7 |
|
BLAKE2b-256 | 86b0fece9ca478b1cbc02a7d8286988b1e8b631560361100b461ed8a8d9a60be |