Skip to main content

Trigger builds of snaps and ubuntu imagesthrough the launchpad API.

Project description

canonicalwebteam.launchpad

Classes for triggering builds of snaps and Ubuntu images through the Launchpad API.

Usage

SnapBuilder

from canonicalwebteam.launchpad import SnapBuilder

snap_builder = SnapBuilder(
    username="build.snapcraft.io",
    token=os.getenv("SNAP_BUILDER_TOKEN"),
    secret=os.getenv("SNAP_BUILDER_SECRET"),
)

snap_name = "new-test-snap"
git_repo = "https://github.com/build-staging-snapcraft-io/test1"
snap_builder.create_snap(snap_name, git_repo)

new_snap = snap_builder.get_snap_by_store_name("new-test-snap")

ImageBuilder

from canonicalwebteam.launchpad import ImageBuilder

image_builder = ImageBuilder(
    username="image.build",
    token=os.getenv("IMAGE_BUILDER_TOKEN"),
    secret=os.getenv("IMAGE_BUILDER_SECRET"),
)

image_builder.build_image(
    board="cm3", system="core16", snaps=["code", "toto"]
)

Test fixtures

Tests check calls against fixtures representing the Launchpad API. These fixtures are generated using vcrpy, based on real calls to the API when the test was first run.

To new tests that rely on new API responses, or if we need to regenerate existing fixtures because the API has changed, the secrets need to be provided to authenticate with the API as follows:

export SNAP_BUILDER_TOKEN={token}
export SNAP_BUILDER_SECRET={secret}
export IMAGE_BUILDER_TOKEN={token}
export IMAGE_BUILDER_SECRET={secret}

rm tests/cassettes/...  # Remove any fixtures you need to regenerate

./setup.py test  # Run tests again to regenerate fixtures

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

canonicalwebteam.launchpad-0.8.3.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

canonicalwebteam.launchpad-0.8.3-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file canonicalwebteam.launchpad-0.8.3.tar.gz.

File metadata

  • Download URL: canonicalwebteam.launchpad-0.8.3.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.10

File hashes

Hashes for canonicalwebteam.launchpad-0.8.3.tar.gz
Algorithm Hash digest
SHA256 b2981d8cfb50b09152e8eb5e4a357ff02f1d09d6a096a70da8868831079ebd3d
MD5 dda776b9b91e170cf6184a1109abba69
BLAKE2b-256 d3251701bfc91f012516c1663669233ec4aaf7541163acb2c3e5572287eab2f5

See more details on using hashes here.

File details

Details for the file canonicalwebteam.launchpad-0.8.3-py3-none-any.whl.

File metadata

  • Download URL: canonicalwebteam.launchpad-0.8.3-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.10

File hashes

Hashes for canonicalwebteam.launchpad-0.8.3-py3-none-any.whl
Algorithm Hash digest
SHA256 56062bf8d0df50fe0ffc6cae886e480fb12e46efeb90be0961ef502768073b9b
MD5 991792295999da11deff362430234649
BLAKE2b-256 48a46873b9989fd43c6d49c7d14f2f518188caf3ec0516bf6b2935728df603b6

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