Compare commits

...

30 Commits

Author SHA1 Message Date
Markus Opolka
cd8f4b825e Updating to Version 3.14.2+180807 2018-08-09 19:23:17 +02:00
Markus Opolka
2683fcee3c Add example docker-compose.yaml for Postgres 2018-08-09 19:22:20 +02:00
Markus Opolka
bef4ac9ae3 Improve entrypoint to check if database is already provisioned 2018-08-09 19:22:17 +02:00
Markus Opolka
4279818967 Fix docker-compose files
- context needed to change
2018-08-08 09:04:17 +02:00
Markus Opolka
481e72194a Updating to Version 3.14.1+180731 2018-08-08 09:02:14 +02:00
Markus Opolka
3f2f632edd Updating to Version 3.14.0+180730 2018-07-31 19:25:16 +02:00
Markus Opolka
13064859d8 Fix Travis build 2018-07-30 10:38:55 +02:00
Markus Opolka
59687fb581 Remove symlinks to entrypoints
- didn't work on DockerHub
2018-07-27 13:59:38 +02:00
Markus Opolka
72aec4b0c5 Updating to Version 3.13.1+180629 2018-07-27 12:28:25 +02:00
Markus Opolka
8e4c52810b Merge pull request #9 from martialblog/add-entrypoint
Add entrypoint and FPM example
2018-07-27 12:25:41 +02:00
Markus Opolka
5dff10bc6e Add examples folder 2018-07-27 12:18:14 +02:00
Markus Opolka
6a91efca55 Update README 2018-07-27 12:15:32 +02:00
Markus Opolka
ed464f3c7d Add example FPM-nginx docker-compose file 2018-07-27 12:15:27 +02:00
Markus Opolka
43ece8e1de Add entrypoint for Container
- Adds config.php if not available
 - Runs console.php for installation
2018-07-27 12:10:35 +02:00
Markus Opolka
f41aff2b87 Fix Regex in Update script 2018-06-15 19:10:29 +02:00
Markus Opolka
dd41cf3b92 Updating to Version 3.12.0+180615 2018-06-15 19:08:46 +02:00
Markus Opolka
6290ea82bf Updating to Version 3.10.0+180611 2018-06-13 06:33:17 +02:00
Markus Opolka
338d5b49d7 Updating to Version 3.8.2+180529 2018-06-04 19:17:13 +02:00
Markus Opolka
806f92df4b Updating to Version 3.8.1+180524 2018-05-29 21:03:40 +02:00
Markus Opolka
107c57f82c Updating to Version 3.8.0+180522 2018-05-25 09:29:05 +02:00
Markus Opolka
8d96eee149 Updating to Version 3.7.3+180516 2018-05-23 08:51:38 +02:00
Markus Opolka
038ccda1f5 Update container-structure-test download path 2018-05-16 12:59:05 +02:00
Markus Opolka
4cf3ada28d Updating to Version 3.7.2+180508 2018-05-16 12:00:26 +02:00
Markus Opolka
1422a7f90c Updating to Version 3.7.1+180424 2018-05-09 09:47:34 +02:00
Markus Opolka
60c137bbb0 Update Update-Script 2018-05-03 18:11:24 +02:00
Markus Opolka
eab1b832b6 Add CONTRIBUTING.md 2018-04-30 13:47:22 +02:00
Markus Opolka
89068ea89d Merge pull request #6 from martialblog/extend-tests
Add container-structore tests
2018-04-30 13:13:07 +02:00
Markus Opolka
c7f1bee380 Add container-structore tests
- Fixes issue #4
2018-04-30 13:06:19 +02:00
Markus Opolka
cb3f54eb90 Add requirements file for Python 2018-04-24 16:06:14 +02:00
Markus Opolka
f143587953 Update to Version 3.7.0+180418 2018-04-24 16:04:53 +02:00
17 changed files with 483 additions and 17 deletions

3
.gitignore vendored
View File

@@ -1,4 +1,5 @@
\#* \#*
.\#* .\#*
.venv/ .venv/
container-structure-test

View File

@@ -2,9 +2,10 @@ sudo: required
language: bash language: bash
services: services:
- docker - docker
matrix: matrix:
include: include:
- env: TEST=limesurvey-apache - env: TAG=martialblog/limesurvey-apache
script: docker build -t martialblog/limesurvey-apache -f apache/Dockerfile . script: cd apache; docker build -q -t $TAG . && cd ..; ./tests/run.sh $TAG
- env: TEST=limesurvey-fpm - env: TAG=martialblog/limesurvey-fpm
script: docker build -t martialblog/limesurvey-fpm -f fpm/Dockerfile . script: cd fpm; docker build -q -t $TAG . && cd ..; ./tests/run.sh $TAG

34
CONTRIBUTING.md Normal file
View File

@@ -0,0 +1,34 @@
# Contributing
Every Pull Request is welcome.
## Upgrading the Version
To upgrade the LimeSurvey Version the ARG variable needs to be changed.
```bash
$ grep Agrep ARG apache/Dockerfile
ARG version='3.7.0+180418'
```
Since this is a reoccuring and boring task, a script is provided.
```bash
# Dependencies
python3 -m venv .venv
source .venv/bin/activate
pip3 install -r requirements.txt
# Upgrades to latest Limesurvey version
./upgrade.py
```
## Testing
In order to make sure the image works as promised, some tests are provided:
```bash
./tests/run.sh
```
For further information: https://github.com/GoogleContainerTools/container-structure-test

View File

@@ -11,7 +11,7 @@ The apache image comes with an Apache Webserver and PHP installed.
# Apache Configuration # Apache Configuration
To change to Apache Webserver configuration mount a Volume into the Container at: To change to Apache Webserver configuration, mount a Volume into the Container at:
- /etc/apache2/sites-available/000-default.conf - /etc/apache2/sites-available/000-default.conf
@@ -19,7 +19,7 @@ See the example configuration provided.
# Using the fpm image # Using the fpm image
To use the fpm image you need an additional web server that can proxy http-request to the fpm-port of the container. To use the fpm image, you need an additional web server that can proxy http-request to the fpm-port of the container. See *docker-compose.fpm.yml* for example
# Using an external database # Using an external database
@@ -27,15 +27,39 @@ LimeSurvey requires an external database (MySQL, PostgreSQL) to run. See *docker
# Persistent data # Persistent data
To preserve the uploaded files assign the upload folder into a volume. See *docker-compose.yml* for details. To preserve the uploaded files assign the upload folder into a volume. See *docker-compose.yml* for example.
Path: */var/www/html/upload/*
# LimeSurvey Configuration # LimeSurvey Configuration
To change to LimeSurvey configuration simply mount a Volume into the Container at: The entrypoint will create a new config.php if none is provided and run the LimeSurvey command line interface for installation.
To change to LimeSurvey configuration, you can mount a Volume into the Container at:
- /my-data/config.php:/var/www/html/application/config/config.php - /my-data/config.php:/var/www/html/application/config/config.php
**Hint**: If this configuration is present, the LimeSurvey Installer will not run. **Hint**: If this configuration is present before the installation, the LimeSurvey Web Installer will not run automatically.
# Environment Variables
| Parameter | Description |
| --------- | ----------- |
| DB_TYPE | Database Type to use. mysql or pgsql |
| DB_HOST | Database server hostname |
| DB_PORT | Database server port |
| DB_NAME | Database name |
| DB_TABLE_PREFIX | Database table prefix |
| DB_USERNAME | Database user |
| DB_PASSWORD | Database user's password |
| ADMIN_USER | LimeSurvey Admin User |
| ADMIN_NAME | LimeSurvey Admin Username |
| ADMIN_EMAIL | LimeSurvey Admin Email |
| ADMIN_PASSWORD | LimeSurvey Admin Password |
| PUBLIC_URL | Public URL for public scripts |
| URL_FORMAT | URL Format. path or get |
For further details on the settings see: https://manual.limesurvey.org/Optional_settings#Advanced_Path_Settings
# References # References

View File

@@ -1,6 +1,6 @@
FROM php:7.2-apache FROM php:7.2-apache
LABEL maintainer="markus@martialblog.de" LABEL maintainer="markus@martialblog.de"
ARG version='3.6.3+180416' ARG version='3.14.2+180807'
# Install OS dependencies # Install OS dependencies
RUN apt-get update && \ RUN apt-get update && \
@@ -12,6 +12,7 @@ RUN apt-get update && \
libkrb5-dev \ libkrb5-dev \
libpng-dev \ libpng-dev \
libpq-dev \ libpq-dev \
netcat \
&& apt-get autoclean; apt-get autoremove && \ && apt-get autoclean; apt-get autoremove && \
rm -rf /var/lib/apt/lists/* rm -rf /var/lib/apt/lists/*
@@ -38,3 +39,7 @@ ADD "https://github.com/LimeSurvey/LimeSurvey/archive/${version}.tar.gz" /tmp
RUN tar xzvf "/tmp/${version}.tar.gz" --strip-components=1 -C /var/www/html/ && \ RUN tar xzvf "/tmp/${version}.tar.gz" --strip-components=1 -C /var/www/html/ && \
rm "/tmp/${version}.tar.gz" && \ rm "/tmp/${version}.tar.gz" && \
chown -R www-data:www-data /var/www/html chown -R www-data:www-data /var/www/html
COPY entrypoint.sh entrypoint.sh
ENTRYPOINT ["/var/www/html/entrypoint.sh"]
CMD ["apache2-foreground"]

91
apache/entrypoint.sh Executable file
View File

@@ -0,0 +1,91 @@
#!/bin/bash
# Entrypoint for Docker Container
DB_TYPE=${DB_TYPE:-'mysql'}
DB_HOST=${DB_HOST:-'mysql'}
DB_PORT=${DB_PORT:-'3306'}
DB_NAME=${DB_NAME:-'limesurvey'}
DB_TABLE_PREFIX=${DB_TABLE_PREFIX:-'lime_'}
DB_USERNAME=${DB_USERNAME:-'limesurvey'}
DB_PASSWORD=${DB_PASSWORD:-}
ADMIN_USER=${ADMIN_USER:-'admin'}
ADMIN_NAME=${ADMIN_NAME:-'admin'}
ADMIN_EMAIL=${ADMIN_EMAIL:-'foobar@example.com'}
ADMIN_PASSWORD=${ADMIN_PASSWORD:-'-'}
PUBLIC_URL=${PUBLIC_URL:-}
URL_FORMAT=${URL_FORMAT:-'path'}
# Check if database is available
until nc -z -v -w30 $DB_HOST $DB_PORT
do
echo "Info: Waiting for database connection..."
sleep 5
done
# Check if already provisioned
if [ -f application/config/config.php ]; then
echo 'Info: config.php already provisioned'
else
echo 'Info: Generating config.php'
if [ "$DB_TYPE" = 'mysql' ]; then
echo 'Info: Using MySQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8mb4'}
cp application/config/config-sample-mysql.php application/config/config.php
fi
if [ "$DB_TYPE" = 'pgsql' ]; then
echo 'Info: Using PostgreSQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8'}
cp application/config/config-sample-pgsql.php application/config/config.php
fi
# Set Database config
sed -i "s#\('connectionString' => \).*,\$#\\1'${DB_TYPE}:host=${DB_HOST};port=${DB_PORT};dbname=${DB_NAME};',#g" application/config/config.php
sed -i "s#\('username' => \).*,\$#\\1'${DB_USERNAME}',#g" application/config/config.php
sed -i "s#\('password' => \).*,\$#\\1'${DB_PASSWORD}',#g" application/config/config.php
sed -i "s#\('charset' => \).*,\$#\\1'${DB_CHARSET}',#g" application/config/config.php
sed -i "s#\('tablePrefix' => \).*,\$#\\1'${DB_TABLE_PREFIX}',#g" application/config/config.php
# Set URL config
sed -i "s#\('urlFormat' => \).*,\$#\\1'${URL_FORMAT}',#g" application/config/config.php
# Set Public URL
if [ -z "$PUBLIC_URL" ]; then
echo 'Info: Setting PublicURL'
sed -i "s#\('debug'=>0,\)\$#'publicurl'=>'${PUBLIC_URL}',\n\t\t\\1 #g" application/config/config.php
fi
fi
# Check if LimeSurvey database is provisioned
echo 'Info: Check if database already provisioned. Nevermind the Stack trace.'
php application/commands/console.php updatedb
if [ $? -eq 0 ]; then
echo 'Info: Database already provisioned'
else
# Check if DB_PASSWORD is set
if [ -z "$DB_PASSWORD" ]; then
echo >&2 'Error: Missing DB_PASSWORD'
exit 1
fi
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
echo ''
echo 'Running console.php install'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL
fi
exec "$@"

35
docker-compose.fpm.yml Normal file
View File

@@ -0,0 +1,35 @@
version: "3.0"
services:
limesurvey:
build:
context: fpm/
dockerfile: Dockerfile
volumes:
- /tmp/upload/:/var/www/html/upload/
- lime:/var/www/html
links:
- lime-db
depends_on:
- lime-db
environment:
- "DB_HOST=docker-limesurvey_lime-db_1"
- "DB_PASSWORD=secret"
- "ADMIN_PASSWORD=foobar"
lime-web:
image: nginx
links:
- limesurvey
ports:
- "8080:80"
volumes:
- ./examples/nginx.conf:/etc/nginx/nginx.conf:ro
- lime:/var/www/html
lime-db:
image: mysql:5.7
environment:
- "MYSQL_USER=limesurvey"
- "MYSQL_DATABASE=limesurvey"
- "MYSQL_PASSWORD=secret"
- "MYSQL_ROOT_PASSWORD=secret"
volumes:
lime:

26
docker-compose.pgsql.yml Normal file
View File

@@ -0,0 +1,26 @@
version: "3.0"
services:
limesurvey:
build:
context: apache/
dockerfile: Dockerfile
volumes:
- /tmp/upload/:/var/www/html/upload/
links:
- lime-db
depends_on:
- lime-db
ports:
- "8080:80"
environment:
- "DB_TYPE=pgsql"
- "DB_PORT=5432"
- "DB_HOST=docker-limesurvey_lime-db_1"
- "DB_PASSWORD=secret"
- "ADMIN_PASSWORD=foobar"
lime-db:
image: postgres:10
environment:
- "POSTGRES_USER=limesurvey"
- "POSTGRES_DB=limesurvey"
- "POSTGRES_PASSWORD=secret"

View File

@@ -2,8 +2,8 @@ version: "3.0"
services: services:
limesurvey: limesurvey:
build: build:
context: . context: apache/
dockerfile: apache/Dockerfile dockerfile: Dockerfile
volumes: volumes:
- /tmp/upload/:/var/www/html/upload/ - /tmp/upload/:/var/www/html/upload/
links: links:
@@ -12,6 +12,10 @@ services:
- lime-db - lime-db
ports: ports:
- "8080:80" - "8080:80"
environment:
- "DB_HOST=docker-limesurvey_lime-db_1"
- "DB_PASSWORD=secret"
- "ADMIN_PASSWORD=foobar"
lime-db: lime-db:
image: mysql:5.7 image: mysql:5.7
environment: environment:

37
examples/nginx.conf Normal file
View File

@@ -0,0 +1,37 @@
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
server {
listen 80;
index index.php;
set $host_path "/var/www/html";
root /var/www/html;
server_name localhost;
charset utf-8;
location / {
try_files $uri /index.php?$args;
}
location ~ ^/(protected|framework|themes/\w+/views) {
deny all;
}
location ~ \.(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|rar)$ {
try_files $uri =404;
}
location ~ \.php$ {
fastcgi_split_path_info ^(.+\.php)(.*)$;
try_files $uri index.php;
include fastcgi_params;
fastcgi_index index.php;
fastcgi_pass limesurvey:9000;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
}
}
}

View File

@@ -1,6 +1,6 @@
FROM php:7.2-fpm FROM php:7.2-fpm
LABEL maintainer="markus@martialblog.de" LABEL maintainer="markus@martialblog.de"
ARG version='3.6.3+180416' ARG version='3.14.2+180807'
# Install OS dependencies # Install OS dependencies
RUN apt-get update && \ RUN apt-get update && \
@@ -12,6 +12,7 @@ RUN apt-get update && \
libkrb5-dev \ libkrb5-dev \
libpng-dev \ libpng-dev \
libpq-dev \ libpq-dev \
netcat \
&& apt-get autoclean; apt-get autoremove && \ && apt-get autoclean; apt-get autoremove && \
rm -rf /var/lib/apt/lists/* rm -rf /var/lib/apt/lists/*
@@ -38,3 +39,9 @@ ADD "https://github.com/LimeSurvey/LimeSurvey/archive/${version}.tar.gz" /tmp
RUN tar xzvf "/tmp/${version}.tar.gz" --strip-components=1 -C /var/www/html/ && \ RUN tar xzvf "/tmp/${version}.tar.gz" --strip-components=1 -C /var/www/html/ && \
rm "/tmp/${version}.tar.gz" && \ rm "/tmp/${version}.tar.gz" && \
chown -R www-data:www-data /var/www/html chown -R www-data:www-data /var/www/html
EXPOSE 9000
COPY entrypoint.sh entrypoint.sh
ENTRYPOINT ["/var/www/html/entrypoint.sh"]
CMD ["php-fpm"]

91
fpm/entrypoint.sh Executable file
View File

@@ -0,0 +1,91 @@
#!/bin/bash
# Entrypoint for Docker Container
DB_TYPE=${DB_TYPE:-'mysql'}
DB_HOST=${DB_HOST:-'mysql'}
DB_PORT=${DB_PORT:-'3306'}
DB_NAME=${DB_NAME:-'limesurvey'}
DB_TABLE_PREFIX=${DB_TABLE_PREFIX:-'lime_'}
DB_USERNAME=${DB_USERNAME:-'limesurvey'}
DB_PASSWORD=${DB_PASSWORD:-}
ADMIN_USER=${ADMIN_USER:-'admin'}
ADMIN_NAME=${ADMIN_NAME:-'admin'}
ADMIN_EMAIL=${ADMIN_EMAIL:-'foobar@example.com'}
ADMIN_PASSWORD=${ADMIN_PASSWORD:-'-'}
PUBLIC_URL=${PUBLIC_URL:-}
URL_FORMAT=${URL_FORMAT:-'path'}
# Check if database is available
until nc -z -v -w30 $DB_HOST $DB_PORT
do
echo "Info: Waiting for database connection..."
sleep 5
done
# Check if already provisioned
if [ -f application/config/config.php ]; then
echo 'Info: config.php already provisioned'
else
echo 'Info: Generating config.php'
if [ "$DB_TYPE" = 'mysql' ]; then
echo 'Info: Using MySQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8mb4'}
cp application/config/config-sample-mysql.php application/config/config.php
fi
if [ "$DB_TYPE" = 'pgsql' ]; then
echo 'Info: Using PostgreSQL configuration'
DB_CHARSET=${DB_CHARSET:-'utf8'}
cp application/config/config-sample-pgsql.php application/config/config.php
fi
# Set Database config
sed -i "s#\('connectionString' => \).*,\$#\\1'${DB_TYPE}:host=${DB_HOST};port=${DB_PORT};dbname=${DB_NAME};',#g" application/config/config.php
sed -i "s#\('username' => \).*,\$#\\1'${DB_USERNAME}',#g" application/config/config.php
sed -i "s#\('password' => \).*,\$#\\1'${DB_PASSWORD}',#g" application/config/config.php
sed -i "s#\('charset' => \).*,\$#\\1'${DB_CHARSET}',#g" application/config/config.php
sed -i "s#\('tablePrefix' => \).*,\$#\\1'${DB_TABLE_PREFIX}',#g" application/config/config.php
# Set URL config
sed -i "s#\('urlFormat' => \).*,\$#\\1'${URL_FORMAT}',#g" application/config/config.php
# Set Public URL
if [ -z "$PUBLIC_URL" ]; then
echo 'Info: Setting PublicURL'
sed -i "s#\('debug'=>0,\)\$#'publicurl'=>'${PUBLIC_URL}',\n\t\t\\1 #g" application/config/config.php
fi
fi
# Check if LimeSurvey database is provisioned
echo 'Info: Check if database already provisioned. Nevermind the Stack trace.'
php application/commands/console.php updatedb
if [ $? -eq 0 ]; then
echo 'Info: Database already provisioned'
else
# Check if DB_PASSWORD is set
if [ -z "$DB_PASSWORD" ]; then
echo >&2 'Error: Missing DB_PASSWORD'
exit 1
fi
# Check if DB_PASSWORD is set
if [ -z "$ADMIN_PASSWORD" ]; then
echo >&2 'Error: Missing ADMIN_PASSWORD'
exit 1
fi
echo ''
echo 'Running console.php install'
php application/commands/console.php install $ADMIN_USER $ADMIN_PASSWORD $ADMIN_NAME $ADMIN_EMAIL
fi
exec "$@"

1
requirements.txt Normal file
View File

@@ -0,0 +1 @@
feedparser==5.2.1

84
tests/image_tests.yaml Normal file
View File

@@ -0,0 +1,84 @@
schemaVersion: "2.0.0"
globalEnvVars:
- key: "PATH"
value: "/env/bin:$PATH"
fileContentTests:
- name: 'Limesurvey admin file content'
path: '/var/www/html/admin/index.php'
expectedContents: ['LimeSurvey']
- name: 'Entrypoint file content'
path: '/var/www/html/entrypoint.sh'
expectedContents: ['console.php', 'ADMIN_USER']
fileExistenceTests:
- name: 'Limesurvey files'
path: '/var/www/html/index.php'
shouldExist: true
permissions: '-rw-rw-r--'
- name: 'Limesurvey admin files'
path: '/var/www/html/admin/index.php'
shouldExist: true
permissions: '-rw-rw-r--'
- name: 'Ldap syslink'
path: '/usr/lib/x86_64-linux-gnu/libldap.so'
shouldExist: true
- name: "Dependencies - PHP - gd"
path: '/usr/local/etc/php/conf.d/docker-php-ext-gd.ini'
shouldExist: true
- name: "Dependencies - PHP - imap"
path: '/usr/local/etc/php/conf.d/docker-php-ext-imap.ini'
shouldExist: true
- name: "Dependencies - PHP - ldap"
path: '/usr/local/etc/php/conf.d/docker-php-ext-ldap.ini'
shouldExist: true
- name: "Dependencies - PHP - pgsql"
path: '/usr/local/etc/php/conf.d/docker-php-ext-pgsql.ini'
shouldExist: true
- name: "Dependencies - PHP - zip"
path: '/usr/local/etc/php/conf.d/docker-php-ext-zip.ini'
shouldExist: true
- name: "Dependencies - PHP - sodium"
path: '/usr/local/etc/php/conf.d/docker-php-ext-sodium.ini'
shouldExist: true
- name: "Dependencies - PHP - pdo_mysql"
path: '/usr/local/etc/php/conf.d/docker-php-ext-pdo_mysql.ini'
shouldExist: true
- name: "Dependencies - PHP - pdo_pgsql"
path: '/usr/local/etc/php/conf.d/docker-php-ext-pdo_pgsql.ini'
shouldExist: true
commandTests:
- name: "Dependencies - netcat"
command: "dpkg"
args: ["-l", "netcat"]
exitCode: 0
- name: "Dependencies - libldap2-dev"
command: "dpkg"
args: ["-l", "libldap2-dev"]
exitCode: 0
- name: "Dependencies - zlib1g-dev"
command: "dpkg"
args: ["-l", "zlib1g-dev"]
exitCode: 0
- name: "Dependencies - libc-client-dev"
command: "dpkg"
args: ["-l", "libc-client-dev"]
exitCode: 0
- name: "Dependencies - libkrb5-dev"
command: "dpkg"
args: ["-l", "libkrb5-dev"]
exitCode: 0
- name: "Dependencies - libpng-dev"
command: "dpkg"
args: ["-l", "libpng-dev"]
exitCode: 0
- name: "Dependencies - libpq-dev"
command: "dpkg"
args: ["-l", "libpq-dev"]
exitCode: 0
- name: "Dependencies - PHP Modules"
command: "php"
args: ["-m"]
expectedOutput: ["ldap", "zip", "pdo_mysql", "pdo_sqlite", "gd", "mbstring", "PDO", "imap"]

11
tests/run.sh Executable file
View File

@@ -0,0 +1,11 @@
#!/usr/bin/env bash
IMAGE=$1
if [ ! -f container-structure-test ]; then
curl -LO https://storage.googleapis.com/container-structure-test/latest/container-structure-test-linux-amd64
mv container-structure-test-linux-amd64 container-structure-test
chmod +x container-structure-test
fi
./container-structure-test test --image $IMAGE --config tests/image_tests.yaml

View File

@@ -1,6 +1,7 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
import argparse
import feedparser import feedparser
import sys import sys
import subprocess import subprocess
@@ -17,15 +18,25 @@ docker_feed = feedparser.parse(docker_feed_url)
limesv_current_release = limesv_feed.entries[0].title_detail.value limesv_current_release = limesv_feed.entries[0].title_detail.value
docker_current_release = docker_feed.entries[0].title_detail.value docker_current_release = docker_feed.entries[0].title_detail.value
argumentparser = argparse.ArgumentParser(description='Updates the LimeSurvey Version in the Dockerfiles')
argumentparser.add_argument('--noop', dest='noop', action="store_true", required=False, help="Don't push just commit")
argumentparser.add_argument('--check', dest='check', action="store_true", required=False, help="Only check if there's a new version available")
cmdargs = argumentparser.parse_args()
if limesv_current_release == docker_current_release: if limesv_current_release == docker_current_release:
print('Nothing to do.') print('Nothing to do.')
sys.exit(0) sys.exit(0)
print('New Version {} available. Upgrading...'.format(limesv_current_release)) print('New Version {} available.'.format(limesv_current_release))
commit_message = 'Update to Version {}'.format(limesv_current_release)
if cmdargs.check:
sys.exit(0)
commit_message = 'Updating to Version {}'.format(limesv_current_release)
# Dockerfiles # Dockerfiles
regexp = 's/[0-9]\.[0-9]\.[0-9]+[0-9]*/{new_version}/'.format(new_version=limesv_current_release) regexp = 's/[0-9]+\.[0-9]+\.[0-9]+[0-9]*/{new_version}/'.format(new_version=limesv_current_release)
subprocess.call(['sed', '-i', '-e', regexp, dockerfile_apache]) subprocess.call(['sed', '-i', '-e', regexp, dockerfile_apache])
subprocess.call(['sed', '-i', '-e', regexp, dockerfile_fpm]) subprocess.call(['sed', '-i', '-e', regexp, dockerfile_fpm])
print('> Updated Dockerfiles') print('> Updated Dockerfiles')
@@ -38,6 +49,9 @@ subprocess.call(['git', 'commit', '-m', commit_message])
subprocess.call(['git', 'tag', limesv_current_release]) subprocess.call(['git', 'tag', limesv_current_release])
print('> Created new Commit and Tag') print('> Created new Commit and Tag')
if cmdargs.noop:
sys.exit(0)
# Git Push # Git Push
# subprocess.call(['git', 'push', 'origin', limesv_current_release]) # subprocess.call(['git', 'push', 'origin', limesv_current_release])
subprocess.call(['git', 'push']) subprocess.call(['git', 'push'])