X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=README.md;h=c41874a73c738eef688a1cd27ef1c7e42faafcfc;hb=7c57af2eda8ded7eeae9ced0157bae7fd188af59;hp=5d1390fc9b6211b0a3f4f464ab8e18296b1fbc04;hpb=d4b9c073f5d735326f4b277e957dd760e20f1b72;p=motion.git diff --git a/README.md b/README.md index 5d1390f..c41874a 100644 --- a/README.md +++ b/README.md @@ -1,12 +1,17 @@ # Installation -Requires 3. +Requires Python 3 and a running PostgreSQL installation. + +For a productive environment use a nginx webserver. + To install: ``` virtualenv -p python3 . . bin/activate pip install -r requirements.txt ``` -Then edit config.py.example into config.py with your database connection +Then edit config.py.example into config.py with your database connection and web site settings + +## Development and debug To debug-run linux: ``` @@ -28,6 +33,18 @@ python -m unittest tests/test_motion.py The database schema is automatically installed when the table "schema_version" does not exist and the application is started. +The following user rights can be granted: +- create: user is able to create a new motion +- vote: user is able to vote running motions +- cancel: user is able to cancel a running motion +- finish: user is able to close a running motion +- audit: user is able to see given votes of a finished motion + +To grant right use the following (here with vote right as example): +- on all groups add "vote:*" +- on one given group add "vote:group1" +- on two given groups add "vote:group1 vote:group2" + # Usage Within the motion content markdown can be used for formatting e.g. @@ -86,3 +103,79 @@ fastcgi_param USER_ROLES $motion_user_role; fastcgi_pass unix:/motion-socket/motion.fcgi; } ``` + +# Configuration for a Jenkins Freestyle Project + +## Preconditions for Jenkins system + +* Python 3 installed with: + + python3 virtualenv python3-pip + +* PostgreSQL server installed with motion database and database user + + +## Add freestyle project + +### Source-Code-Management + +Adjust Git settings + +### Build Environment + +Add Bindings + +Add Username and password (separated) + +Enter username (DB_USER) and password (DB_PW) according to database credentials + +### Build + +Add build step shell + +Add the command + +``` +rm -rf env +virtualenv -p python3 env +. env/bin/activate +pip3 install -r requirements.txt + + +cat > config.py << EOF +DATABASE="pq://IP-ADDRESS/motion" +USER="${DB_USER}" +PASSWORD="${DB_PW}" +EOF + +python3 jenkins_job.py +``` + +If an IPv6 address is used the following needs to be added to the script to fix a bug of the IPv6 literal translation: +(https://github.com/python-postgres/fe/issues/104) + +``` +patch env/lib/python3*/site-packages/postgresql/versionstring.py < ( + Split a PostgreSQL version string into a tuple + (major,minor,patch,...,state_class,state_level) + """ +- v = vstr.strip().split('.') ++ v = vstr.strip().split(' ')[0].split('.') + + # Get rid of the numbers around the state_class (beta,a,dev,alpha, etc) + state_class = v[-1].strip('0123456789') +EOF +``` + +### Post build actions + +Add Publish JUnit test result report - test report XMLs + +``` +python_tests_xml/* +```