Skip to main content

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

cubetoolkit-0.3.1.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

cubetoolkit-0.3.1-py2-none-any.whl (9.6 kB view details)

Uploaded Python 2

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

Hashes for cubetoolkit-0.3.1.tar.gz
Algorithm Hash digest
SHA256 e5032d3186ee620581b77204f93c29543a67e93c9d57842c86993f5a9d17795a
MD5 4569622e73ac1d89cc121d464b8db93b
BLAKE2b-256 412891cbc72643f96e1c4017068b391f49c7040c84792a438387594d8a881549

See more details on using hashes here.

File details

Details for the file cubetoolkit-0.3.1-py2-none-any.whl.

File metadata

File hashes

Hashes for cubetoolkit-0.3.1-py2-none-any.whl
Algorithm Hash digest
SHA256 d4f218dfdd3b1d9b039a5ced07c3ffeb08f24f0fa45a92a5795a8d2c1b9b1f58
MD5 6864e50c17126e71d71af0f0b120deb7
BLAKE2b-256 86b0fece9ca478b1cbc02a7d8286988b1e8b631560361100b461ed8a8d9a60be

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page