Victoria Plugin that allows the creation and DESTRUCTION of SAAS on the cloud.
Project description
Victoria Rebuilder
Victoria Rebuilder is a V. I. C. T. O. R. I. A is a plugin that allows you to run multiple Azure DevOps release pipelines
Features
- Run a series of release pipelines based on a stages most recent successful releases in Azure DevOps.
- Run a series of release pipelines for a stage based off another stage's most recent successful releases in Azure DevOps.
Prerequisites
- Python 3.7+
- Pip
- Pipenv
Installation
pipenv install -U victoria_rebuilder
Usage
Config
There is an example configuration file provided please update it as you see fit using the guidance below.
Access Configuration
access:
access_token: <encoded>
organisation: Organisation
project: Azure DevOps Project
email: user@organisation.com
access_token
: The PAT token associated to the email and organisation. The PAT Token must have Read and Write access to Releases.organisation
: The organisation in Azure DevOps.project
: The project in Azure DevOpsemail
: The email account associated to the PAT token.
Encrypting data for config values
In the config, the access_token
which belongs to the access
section should contain encrypted data. This can be
achieved with the pre-build victoria encrypt
command. Details on this
can be found in the documentation:
- Make sure you've set up your Victoria cloud encryption backend.
- Paste the required value (i.e. the
access_token
) into the following Victoria command like:$ victoria encrypt data <access_token>
- The command should output a YAML object containing fields
data
,iv
,key
andversion
. This is the encrypted value string and can be safely stored in config. Put this YAML object into youraccess
section like:access: access_token: data: <snip> iv: <snip> key: <snip> version: <snip> organisation: Glasswall project: SomeProject email: some@email.com
Deployment Configuration
deployments:
stage: deploy_init_infrastructure
releases:
- name: Platform.Infrastructure
stage: deploy_kubernetes_infrastructure
releases:
- name: Platform.Kubernetes
stage
: Name of the stage. The releases in each stage are all run first before the next stage is completereleases
: List of releases and their name. The name is the name of the release in Azure DevOps
Help text
Usage: victoria rebuilder [OPTIONS] COMMAND [ARGS]...
The rebuilder allows the destruction and rebuilding of environments via
CLI.
Options:
-h, --help Show this message and exit.
Commands:
copy CLI call for rebuilding an environment based off another...
optional flags:
-r, ---resume If you want the rebuilder to use the previous state file.
rebuild CLI call for rebuilding a specific kubernetes environment...
optional flags:
-r, ---resume If you want the rebuilder to use the previous state file.
-a, --auto-retry If a release fails to deploy, instead of prompting the user
for a y/n on retry, it automatically retries the deployment.
CLI Examples
Rebuild an environment
Rebuild is defined as running the release pipelines associated with the stage pent
in this example.
victoria rebuilder rebuild pent
Copy an environment
Copy is defined as running the release for a stage based of an other stage. The use case for this is if you created a new stage and want it to have the same release version as the dev stage.
python rebuilder copy qa pent perf
Would copy the status of qa to pent and perf
Contribution
Bug reports
You can submit a bug report here.
Feature requests
You can request a new feature here.
Vulnerability reports
We prefer vulnerabilities to be reported in private so as to minimise their impact (so we can fix them before they are exploited!). To this end, please email any security vulnerability reports to 'sre@glasswallsolutions.com'. We would appreciate it if you use the issue template in the link below. All vulnerabilities will be acknowledged within one business day.
You can publicly report a security vulnerability here.
Pull requests
We accept pull requests! To contribute:
-
Pick up an unassigned issue from our issue board.
Assign yourself to the issue so other people know you're working on it.
-
Work on your code in a feature branch that's got a descriptive name (like
rework-fancy-integrator
). -
Follow the Google style guide for Python.
We use pylint to lint our code. We run pylint without the 'convention' and 'refactor' message classes. You can lint your code with:
pipenv run pylint victoria_destroyer --disable="C,R"
. We use yapf to automatically format our code. We recommend having it format the code whenever you save. -
Make commits for each part of your pull request. Try not to make too many (if it's a small issue you may only need one).
We try to use the imperative mood in commit message subjects.
-
We expect all new code to have at least 80% test coverage. This is enforced by Codecov.
-
To run tests locally and check coverage, use:
pipenv run pytest tests/ --cov=victoria_rebuilder
. -
When ready to merge, create a pull request from your branch into master.
-
Make sure you link your pull request to the issue(s) it addresses.
-
The CI build will run
for your pull request. If it fails then it cannot be merged. Inspect the output, figure out why it failed, and fix the problem. The CI build will lint your code, run tests, and send coverage/code to Codecov and SonarCloud.
-
Someone will review your pull request and suggest changes if necessary.
-
When everything is signed off, your pull request will be merged! Congrats.
Development
Prerequisites
- Python 3.x
- Pipenv
Quick start
- Clone this repo.
- Run
pipenv sync
- You're good to go. You can run commands using the package inside a
pipenv shell
, and modify the code with your IDE.
License
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 victoria_rebuilder-0.2.2.tar.gz
.
File metadata
- Download URL: victoria_rebuilder-0.2.2.tar.gz
- Upload date:
- Size: 13.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 40d604dd936effbe49638cb85040c58bab812e5db5fca0b40b713a274fe0f210 |
|
MD5 | 673aee53c1976f6254df0911ff563a4f |
|
BLAKE2b-256 | 2fbe71f84220a790fae1d72ba2a76399001cc420312ec90c4a183b81f656d7da |
File details
Details for the file victoria_rebuilder-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: victoria_rebuilder-0.2.2-py3-none-any.whl
- Upload date:
- Size: 12.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.7.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 27d493687e5c9fdd7f94a72dc04ab38fd03c27889b167d0d146a11617922fc18 |
|
MD5 | 4542275ec5c0e96f1528eeb44aa9f8ce |
|
BLAKE2b-256 | 332717c6ed259ec03a0674f1ab6b6fbf5a6e7fce6007ecc5f28405c0c303dd35 |