Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/turulomio/preprod
Easily creation of pre-production and production scripts to automate your deployment
https://github.com/turulomio/preprod
deployment-automation preproduction production scripts
Last synced: 6 days ago
JSON representation
Easily creation of pre-production and production scripts to automate your deployment
- Host: GitHub
- URL: https://github.com/turulomio/preprod
- Owner: turulomio
- License: gpl-3.0
- Created: 2024-05-01T20:08:39.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-07-25T03:59:29.000Z (5 months ago)
- Last Synced: 2024-12-06T07:06:07.085Z (28 days ago)
- Topics: deployment-automation, preproduction, production, scripts
- Language: Python
- Homepage: https://github.com/turulomio/preprod
- Size: 243 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# PreProd [![PyPI - Downloads](https://img.shields.io/pypi/dm/preprod?label=Pypi%20downloads)](https://pypi.org/project/preprod/) [![Tests](https://github.com/turulomio/preprod/actions/workflows/python-app.yml/badge.svg)](https://github.com/turulomio/preprod/actions/workflows/python-app.yml)
Easy creation of pre-production and production scripts to automate your deploymentWhen you're deploying your software in your web server or when you're developing, you often need to modify default settings of your software to addapt them to your needs.
Sometimes, you develop your own scripts to automate this task, but these scripts become more complex each day. That's the reason of this project. PreProd helps you to develop your own deployment script, setting them in a repository.
Preprod uses python code so you don't have to learn any other language.
If your user is root this repository is set in `/etc/preprod` and if your logged as a normal user in `~/.preprod`
Preprod has defined a lot of help commands to make your scripts more visual. They are resumed below and you can call them appending `preprod_commons` python module. Morever you can create your own commands in `{yourrepositorypath}/repository_commons.py` and call them inside your scripts appending `repository_commons` as any other python module.
## Example
For example, We are going to automate e2e test in console using preprod with my frontend project [Calories Tracker](https://github.com/turulomio/calories_tracker/)
First we need to create our PreProd repository. As we said before you can create as root or as a normal user.
```bash
preprod_create_repository
cd /home/your_user/.preprod
mkdir calories_tracker
nano calories_tracker/build
```In calories_tracker/build add the next code
```python
preprod_commons.chdir("/tmp")
preprod_commons.rmtree("/tmp/calories_tracker_build")
preprod_commons.git_clone("https://github.com/turulomio/calories_tracker", "calories_tracker_build")
preprod_commons.chdir("/tmp/calories_tracker_build")
preprod_commons.npm_install()
preprod_commons.run_and_check("npm run build")
```Now if you run `preprod` you can see your scripts (project: calories_tracker, action: build). So just run
```bash
preprod calories_tracker build
```
You'll see in consoleAnd your calories_tracker build is now in `/tmp/calories_tracker_build/dist`
If something goes wrong you can see color logs in `/tmp/preprod_logs_your_user/`
I hope you like it and give me a star.
## Commands
You can see all preprod_commons method [here](doc/PREPROD_COMMANDS.md)
## Changelog
### 1.2.0 (2024-07-25)
- Added branch support to git clone command
- Added number_of_sockets and socket_timeout parameters to nmcli_net_change command### 1.1.0 (2024-07-03)
- Running system with other user changes before to current working directory
- Added kill_from_ps_aux method### 1.0.1 (2024-06-29)
- run_and_check allows to add user and password parameters
- system allows to add user parameter### 0.6.0 (2024-06-23)
- Solved problem creating python virtual environment
- Improving tests procedure. Coverage is now 85% (#42)### 0.5.0 (2024-06-17)
- Added getuser, rm, create_a_file commands
- Improved preprod parameters experience
- poetry_env_info now returns a tuple with the virtual env python executable and pip executable### 0.4.0 (2024-06-08)
- Temporal preprod logs are now created by each user to avoid permissions problems
- Added examples and documentation
- Added poe doc command
- Improved parameters errors### 0.3.0 (2024-05-28)
- Improved description system
- Added makedirs and git clone in different directory
- Improved spanish translations
- Added --version to commands
- Added test with a 84% coverture### 0.2.0 (2024-05-26)
- Added logs in /tmp/preprod_logs/
- Added chown_recursive, chmod_recursive, rsync, poetry_install, poetry_env_info methods to commons### 0.1.0 (2024-05-21)
- Basic functionality