mirror of
https://github.com/wallabag/docker
synced 2025-12-13 09:46:27 +00:00
Compare commits
73 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2a78ed65fe | ||
|
|
cb78d1c98c | ||
|
|
19b6080f31 | ||
|
|
85c82d22c4 | ||
|
|
2ab5b95caf | ||
|
|
2c4fc77b58 | ||
|
|
bffc1412bf | ||
|
|
588c21b192 | ||
|
|
6f2ec8654e | ||
|
|
4143013553 | ||
|
|
eaf63d2098 | ||
|
|
9c6aca3b76 | ||
|
|
e16d9e4113 | ||
|
|
03d1e3a920 | ||
|
|
7c9d8a37e0 | ||
|
|
bdbf7b909a | ||
|
|
bf62096c0e | ||
|
|
f59fb4b67a | ||
|
|
c68fc98e51 | ||
|
|
919f82516c | ||
|
|
2515407009 | ||
|
|
96dd9bc3e3 | ||
|
|
5bde344da3 | ||
|
|
36d4bf58db | ||
|
|
e7b0f9c7f6 | ||
|
|
5a426ce3fa | ||
|
|
75d1b96cc8 | ||
|
|
9241c7d799 | ||
|
|
18d9f742fb | ||
|
|
b5d9ba681c | ||
|
|
b340aaee0a | ||
|
|
746c6e682b | ||
|
|
d7e49fbda9 | ||
|
|
8a68a267ed | ||
|
|
4b00b7f383 | ||
|
|
f1e3a0e2ae | ||
|
|
c2b7c3bbd7 | ||
|
|
7810ca6255 | ||
|
|
4f406f1f1f | ||
|
|
7edde03f39 | ||
|
|
4b4eb85eb1 | ||
|
|
7ac0c31dc1 | ||
|
|
854d1027b8 | ||
|
|
f4517471db | ||
|
|
abb6a98924 | ||
|
|
624616cd9e | ||
|
|
d6ce0cea67 | ||
|
|
673dea7800 | ||
|
|
d21d9c6260 | ||
|
|
886535f767 | ||
|
|
1ad213de86 | ||
|
|
3538a3c8d7 | ||
|
|
92fcba3557 | ||
|
|
98ed4730b3 | ||
|
|
c0c280b606 | ||
|
|
5790e0d029 | ||
|
|
e61cbdb025 | ||
|
|
c12a84557a | ||
|
|
835e9ad84b | ||
|
|
d5aac3e6ed | ||
|
|
e38f9adb8b | ||
|
|
b6db602ece | ||
|
|
659a8f4d3f | ||
|
|
62d1948e15 | ||
|
|
a025d243d1 | ||
|
|
fb13655def | ||
|
|
de07417e8f | ||
|
|
b34d71355d | ||
|
|
8bc63c22ec | ||
|
|
676572b8fe | ||
|
|
d51cc9fe33 | ||
|
|
5c52eee713 | ||
|
|
e2717ea9a9 |
21
.github/workflows/test.yml
vendored
21
.github/workflows/test.yml
vendored
@@ -36,17 +36,16 @@ jobs:
|
|||||||
- name: "Build image"
|
- name: "Build image"
|
||||||
run: docker-compose -f tests/docker-compose.${{ matrix.database }}.yml build
|
run: docker-compose -f tests/docker-compose.${{ matrix.database }}.yml build
|
||||||
|
|
||||||
- name: "Run image"
|
|
||||||
run: docker-compose -f tests/docker-compose.${{ matrix.database }}.yml up -d
|
|
||||||
|
|
||||||
- name: "Install dependencies"
|
- name: "Install dependencies"
|
||||||
run: pip install pytest requests
|
run: pip install pytest pytest-docker requests
|
||||||
|
|
||||||
- name: "Check running instance"
|
|
||||||
run: docker ps
|
|
||||||
|
|
||||||
- name: "Wait 60s"
|
|
||||||
run: sleep 60
|
|
||||||
|
|
||||||
- name: "Run tests"
|
- name: "Run tests"
|
||||||
run: py.test tests/
|
run: py.test --database=${{ matrix.database }} tests/
|
||||||
|
|
||||||
|
- name: "Get docker logs"
|
||||||
|
if: ${{ always() }}
|
||||||
|
run: docker-compose -p "wallabag_${{ matrix.database }}" -f tests/docker-compose.${{ matrix.database }}.yml logs wallabag
|
||||||
|
|
||||||
|
- name: "Cleanup environment"
|
||||||
|
if: ${{ always() }}
|
||||||
|
run: docker-compose -p "wallabag_${{ matrix.database }}" -f tests/docker-compose.${{ matrix.database }}.yml down -v
|
||||||
|
|||||||
25
Dockerfile
25
Dockerfile
@@ -1,3 +1,7 @@
|
|||||||
|
ARG COMPOSER_VERSION=2.5.8
|
||||||
|
|
||||||
|
FROM composer:$COMPOSER_VERSION as composer
|
||||||
|
|
||||||
FROM golang:alpine as builder
|
FROM golang:alpine as builder
|
||||||
|
|
||||||
# envsubst from gettext can not replace env vars with default values
|
# envsubst from gettext can not replace env vars with default values
|
||||||
@@ -5,11 +9,11 @@ FROM golang:alpine as builder
|
|||||||
# flag -ldflags "-s -w" produces a smaller executable
|
# flag -ldflags "-s -w" produces a smaller executable
|
||||||
RUN go install -ldflags "-s -w" -v github.com/a8m/envsubst/cmd/envsubst@v1.3.0
|
RUN go install -ldflags "-s -w" -v github.com/a8m/envsubst/cmd/envsubst@v1.3.0
|
||||||
|
|
||||||
FROM alpine:3.17
|
FROM alpine:3.18
|
||||||
|
|
||||||
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
COPY --from=builder /go/bin/envsubst /usr/bin/envsubst
|
||||||
|
|
||||||
ARG WALLABAG_VERSION=2.5.3
|
ARG WALLABAG_VERSION=2.6.9
|
||||||
|
|
||||||
RUN set -ex \
|
RUN set -ex \
|
||||||
&& apk add --no-cache \
|
&& apk add --no-cache \
|
||||||
@@ -30,6 +34,7 @@ RUN set -ex \
|
|||||||
php81-mbstring \
|
php81-mbstring \
|
||||||
php81-openssl \
|
php81-openssl \
|
||||||
php81-pecl-amqp \
|
php81-pecl-amqp \
|
||||||
|
php81-pecl-imagick \
|
||||||
php81-pdo_mysql \
|
php81-pdo_mysql \
|
||||||
php81-pdo_pgsql \
|
php81-pdo_pgsql \
|
||||||
php81-pdo_sqlite \
|
php81-pdo_sqlite \
|
||||||
@@ -43,6 +48,7 @@ RUN set -ex \
|
|||||||
php81-xmlreader \
|
php81-xmlreader \
|
||||||
php81-tidy \
|
php81-tidy \
|
||||||
php81-intl \
|
php81-intl \
|
||||||
|
php81-sodium \
|
||||||
mariadb-client \
|
mariadb-client \
|
||||||
postgresql14-client \
|
postgresql14-client \
|
||||||
rabbitmq-c \
|
rabbitmq-c \
|
||||||
@@ -53,16 +59,14 @@ RUN set -ex \
|
|||||||
&& ln -sf /usr/sbin/php-fpm81 /usr/sbin/php-fpm \
|
&& ln -sf /usr/sbin/php-fpm81 /usr/sbin/php-fpm \
|
||||||
&& rm -rf /var/cache/apk/* \
|
&& rm -rf /var/cache/apk/* \
|
||||||
&& ln -sf /dev/stdout /var/log/nginx/access.log \
|
&& ln -sf /dev/stdout /var/log/nginx/access.log \
|
||||||
&& ln -sf /dev/stderr /var/log/nginx/error.log \
|
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
||||||
&& curl -s https://getcomposer.org/installer | php \
|
|
||||||
&& mv composer.phar /usr/local/bin/composer \
|
COPY --from=composer /usr/bin/composer /usr/local/bin/composer
|
||||||
&& composer selfupdate 2.2.18 \
|
|
||||||
&& rm -rf /root/.composer/*
|
|
||||||
|
|
||||||
COPY root /
|
COPY root /
|
||||||
|
|
||||||
RUN set -ex \
|
RUN set -ex \
|
||||||
&& curl -L -o /tmp/wallabag.tar.gz https://github.com/wallabag/wallabag/archive/$WALLABAG_VERSION.tar.gz \
|
&& curl -L -o /tmp/wallabag.tar.gz https://github.com/wallabag/wallabag/releases/download/$WALLABAG_VERSION/wallabag-$WALLABAG_VERSION.tar.gz \
|
||||||
&& tar xvf /tmp/wallabag.tar.gz -C /tmp \
|
&& tar xvf /tmp/wallabag.tar.gz -C /tmp \
|
||||||
&& mkdir /var/www/wallabag \
|
&& mkdir /var/www/wallabag \
|
||||||
&& mv /tmp/wallabag-*/* /var/www/wallabag/ \
|
&& mv /tmp/wallabag-*/* /var/www/wallabag/ \
|
||||||
@@ -74,6 +78,11 @@ RUN set -ex \
|
|||||||
&& rm -rf /root/.composer/* /var/www/wallabag/var/cache/* /var/www/wallabag/var/logs/* /var/www/wallabag/var/sessions/* \
|
&& rm -rf /root/.composer/* /var/www/wallabag/var/cache/* /var/www/wallabag/var/logs/* /var/www/wallabag/var/sessions/* \
|
||||||
&& chown -R nobody:nobody /var/www/wallabag
|
&& chown -R nobody:nobody /var/www/wallabag
|
||||||
|
|
||||||
|
ENV PATH="${PATH}:/var/www/wallabag/bin"
|
||||||
|
|
||||||
|
# Set console entry path
|
||||||
|
WORKDIR /var/www/wallabag
|
||||||
|
|
||||||
EXPOSE 80
|
EXPOSE 80
|
||||||
ENTRYPOINT ["/entrypoint.sh"]
|
ENTRYPOINT ["/entrypoint.sh"]
|
||||||
CMD ["wallabag"]
|
CMD ["wallabag"]
|
||||||
|
|||||||
21
README.md
21
README.md
@@ -27,15 +27,12 @@ Default login is `wallabag:wallabag`.
|
|||||||
- `-e SYMFONY__ENV__DATABASE_TABLE_PREFIX=...` (defaults to "wallabag_". Specifies the prefix for each database table)
|
- `-e SYMFONY__ENV__DATABASE_TABLE_PREFIX=...` (defaults to "wallabag_". Specifies the prefix for each database table)
|
||||||
- `-e SYMFONY__ENV__SECRET=...` (defaults to "ovmpmAWXRCabNlMgzlzFXDYmCFfzGv")
|
- `-e SYMFONY__ENV__SECRET=...` (defaults to "ovmpmAWXRCabNlMgzlzFXDYmCFfzGv")
|
||||||
- `-e SYMFONY__ENV__LOCALE=...` (default to en)
|
- `-e SYMFONY__ENV__LOCALE=...` (default to en)
|
||||||
- `-e SYMFONY__ENV__MAILER_HOST=...` (defaults to "127.0.0.1", the SMTP host)
|
- `-e SYMFONY__ENV__MAILER_DSN=...` (defaults to "smtp://127.0.0.1")
|
||||||
- `-e SYMFONY__ENV__MAILER_USER=...` (defaults to "~", the SMTP user)
|
|
||||||
- `-e SYMFONY__ENV__MAILER_PASSWORD=...`(defaults to "~", the SMTP password)
|
|
||||||
- `-e SYMFONY__ENV__FROM_EMAIL=...`(defaults to "`wallabag@example.com`", the address wallabag uses for outgoing emails)
|
- `-e SYMFONY__ENV__FROM_EMAIL=...`(defaults to "`wallabag@example.com`", the address wallabag uses for outgoing emails)
|
||||||
- `-e SYMFONY__ENV__TWOFACTOR_AUTH=...` (defaults to "true", enable or disable two-factor authentication)
|
|
||||||
- `-e SYMFONY__ENV__TWOFACTOR_SENDER=...` (defaults to "`no-reply@wallabag.org`", the address wallabag uses for two-factor emails)
|
- `-e SYMFONY__ENV__TWOFACTOR_SENDER=...` (defaults to "`no-reply@wallabag.org`", the address wallabag uses for two-factor emails)
|
||||||
- `-e SYMFONY__ENV__FOSUSER_REGISTRATION=...`(defaults to "true", enable or disable public user registration)
|
- `-e SYMFONY__ENV__FOSUSER_REGISTRATION=...`(defaults to "false", enable or disable public user registration)
|
||||||
- `-e SYMFONY__ENV__FOSUSER_CONFIRMATION=...`(defaults to "true", enable or disable registration confirmation)
|
- `-e SYMFONY__ENV__FOSUSER_CONFIRMATION=...`(defaults to "true", enable or disable registration confirmation)
|
||||||
- `-e SYMFONY__ENV__DOMAIN_NAME=...` defaults to "`https://your-wallabag-url-instance.com`", the URL of your wallabag instance)
|
- `-e SYMFONY__ENV__DOMAIN_NAME=...` defaults to "`https://your-wallabag-instance.wallabag.org`", the URL of your wallabag instance)
|
||||||
- `-e SYMFONY__ENV__REDIS_SCHEME=...` (defaults to "tcp", protocol to use to communicate with the target server (tcp, unix, or http))
|
- `-e SYMFONY__ENV__REDIS_SCHEME=...` (defaults to "tcp", protocol to use to communicate with the target server (tcp, unix, or http))
|
||||||
- `-e SYMFONY__ENV__REDIS_HOST=...` (defaults to "redis", IP or hostname of the target server)
|
- `-e SYMFONY__ENV__REDIS_HOST=...` (defaults to "redis", IP or hostname of the target server)
|
||||||
- `-e SYMFONY__ENV__REDIS_PORT=...` (defaults to "6379", port of the target host)
|
- `-e SYMFONY__ENV__REDIS_PORT=...` (defaults to "6379", port of the target host)
|
||||||
@@ -44,6 +41,7 @@ Default login is `wallabag:wallabag`.
|
|||||||
- `-e SYMFONY__ENV__SENTRY_DSN=...` (defaults to "~", this is the data source name for sentry)
|
- `-e SYMFONY__ENV__SENTRY_DSN=...` (defaults to "~", this is the data source name for sentry)
|
||||||
- `-e POPULATE_DATABASE=...`(defaults to "True". Does the DB has to be populated or is it an existing one)
|
- `-e POPULATE_DATABASE=...`(defaults to "True". Does the DB has to be populated or is it an existing one)
|
||||||
- `-e SYMFONY__ENV__SERVER_NAME=...` (defaults to "Your wallabag instance". Specifies a user-friendly name for the 2FA issuer)
|
- `-e SYMFONY__ENV__SERVER_NAME=...` (defaults to "Your wallabag instance". Specifies a user-friendly name for the 2FA issuer)
|
||||||
|
- `-e PHP_MEMORY_LIMIT=...` (allows you to change the PHP `memory_limit` value. defaults to 128M, and should be a number and unit, eg. 512K, 128M, 2G, or a number of bytes)
|
||||||
|
|
||||||
## SQLite
|
## SQLite
|
||||||
|
|
||||||
@@ -115,6 +113,7 @@ version: '3'
|
|||||||
services:
|
services:
|
||||||
wallabag:
|
wallabag:
|
||||||
image: wallabag/wallabag
|
image: wallabag/wallabag
|
||||||
|
restart: unless-stopped
|
||||||
environment:
|
environment:
|
||||||
- MYSQL_ROOT_PASSWORD=wallaroot
|
- MYSQL_ROOT_PASSWORD=wallaroot
|
||||||
- SYMFONY__ENV__DATABASE_DRIVER=pdo_mysql
|
- SYMFONY__ENV__DATABASE_DRIVER=pdo_mysql
|
||||||
@@ -125,18 +124,16 @@ services:
|
|||||||
- SYMFONY__ENV__DATABASE_PASSWORD=wallapass
|
- SYMFONY__ENV__DATABASE_PASSWORD=wallapass
|
||||||
- SYMFONY__ENV__DATABASE_CHARSET=utf8mb4
|
- SYMFONY__ENV__DATABASE_CHARSET=utf8mb4
|
||||||
- SYMFONY__ENV__DATABASE_TABLE_PREFIX="wallabag_"
|
- SYMFONY__ENV__DATABASE_TABLE_PREFIX="wallabag_"
|
||||||
- SYMFONY__ENV__MAILER_HOST=127.0.0.1
|
- SYMFONY__ENV__MAILER_DSN=smtp://127.0.0.1
|
||||||
- SYMFONY__ENV__MAILER_USER=~
|
|
||||||
- SYMFONY__ENV__MAILER_PASSWORD=~
|
|
||||||
- SYMFONY__ENV__FROM_EMAIL=wallabag@example.com
|
- SYMFONY__ENV__FROM_EMAIL=wallabag@example.com
|
||||||
- SYMFONY__ENV__DOMAIN_NAME=https://your-wallabag-url-instance.com
|
- SYMFONY__ENV__DOMAIN_NAME=https://your-wallabag-instance.wallabag.org
|
||||||
- SYMFONY__ENV__SERVER_NAME="Your wallabag instance"
|
- SYMFONY__ENV__SERVER_NAME="Your wallabag instance"
|
||||||
ports:
|
ports:
|
||||||
- "80"
|
- "80"
|
||||||
volumes:
|
volumes:
|
||||||
- /opt/wallabag/images:/var/www/wallabag/web/assets/images
|
- /opt/wallabag/images:/var/www/wallabag/web/assets/images
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "wget" ,"--no-verbose", "--tries=1", "--spider", "http://localhost"]
|
test: ["CMD", "wget" ,"--no-verbose", "--tries=1", "--spider", "http://localhost/api/info"]
|
||||||
interval: 1m
|
interval: 1m
|
||||||
timeout: 3s
|
timeout: 3s
|
||||||
depends_on:
|
depends_on:
|
||||||
@@ -144,6 +141,7 @@ services:
|
|||||||
- redis
|
- redis
|
||||||
db:
|
db:
|
||||||
image: mariadb
|
image: mariadb
|
||||||
|
restart: unless-stopped
|
||||||
environment:
|
environment:
|
||||||
- MYSQL_ROOT_PASSWORD=wallaroot
|
- MYSQL_ROOT_PASSWORD=wallaroot
|
||||||
volumes:
|
volumes:
|
||||||
@@ -154,6 +152,7 @@ services:
|
|||||||
timeout: 3s
|
timeout: 3s
|
||||||
redis:
|
redis:
|
||||||
image: redis:alpine
|
image: redis:alpine
|
||||||
|
restart: unless-stopped
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "redis-cli", "ping"]
|
test: ["CMD", "redis-cli", "ping"]
|
||||||
interval: 20s
|
interval: 20s
|
||||||
|
|||||||
4
conftest.py
Normal file
4
conftest.py
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import pytest
|
||||||
|
|
||||||
|
def pytest_addoption(parser):
|
||||||
|
parser.addoption("--database", action="store", default="default")
|
||||||
@@ -23,9 +23,12 @@ install_wallabag() {
|
|||||||
provisioner() {
|
provisioner() {
|
||||||
SYMFONY__ENV__DATABASE_DRIVER=${SYMFONY__ENV__DATABASE_DRIVER:-pdo_sqlite}
|
SYMFONY__ENV__DATABASE_DRIVER=${SYMFONY__ENV__DATABASE_DRIVER:-pdo_sqlite}
|
||||||
POPULATE_DATABASE=${POPULATE_DATABASE:-True}
|
POPULATE_DATABASE=${POPULATE_DATABASE:-True}
|
||||||
|
SQLITE_DB_DIR="/var/www/wallabag/data/db"
|
||||||
|
SQLITE_DB_FILEPATH="$SQLITE_DB_DIR/wallabag.sqlite"
|
||||||
|
|
||||||
# Replace environment variables
|
# Replace environment variables
|
||||||
envsubst < /etc/wallabag/parameters.template.yml > app/config/parameters.yml
|
envsubst < /etc/wallabag/parameters.template.yml > app/config/parameters.yml
|
||||||
|
envsubst < /etc/wallabag/php-wallabag.template.ini > /etc/php81/conf.d/50_wallabag.ini
|
||||||
|
|
||||||
# Wait for external database
|
# Wait for external database
|
||||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] || [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_pgsql" ] ; then
|
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] || [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_pgsql" ] ; then
|
||||||
@@ -33,10 +36,18 @@ provisioner() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Configure SQLite database
|
# Configure SQLite database
|
||||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_sqlite" ] && [ ! -f "/var/www/wallabag/data/db/wallabag.sqlite" ] ; then
|
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_sqlite" ]; then
|
||||||
|
# mkdir and chown are mandatory for local folder binding
|
||||||
|
if [ ! -f "$SQLITE_DB_FILEPATH" ]; then
|
||||||
|
mkdir -p "$SQLITE_DB_DIR"
|
||||||
|
chown nobody: "$SQLITE_DB_DIR"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -s "$SQLITE_DB_FILEPATH" ]; then
|
||||||
echo "Configuring the SQLite database ..."
|
echo "Configuring the SQLite database ..."
|
||||||
install_wallabag
|
install_wallabag
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Configure MySQL / MariaDB database
|
# Configure MySQL / MariaDB database
|
||||||
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] && [ "$POPULATE_DATABASE" = "True" ] && [ "$MYSQL_ROOT_PASSWORD" != "" ] ; then
|
if [ "$SYMFONY__ENV__DATABASE_DRIVER" = "pdo_mysql" ] && [ "$POPULATE_DATABASE" = "True" ] && [ "$MYSQL_ROOT_PASSWORD" != "" ] ; then
|
||||||
@@ -87,9 +98,9 @@ provisioner() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if [ "$COMMAND_ARG1" = "wallabag" ]; then
|
if [ "$COMMAND_ARG1" = "wallabag" ]; then
|
||||||
echo "Starting Wallabag ..."
|
echo "Starting wallabag ..."
|
||||||
provisioner
|
provisioner
|
||||||
echo "Wallabag is ready!"
|
echo "wallabag is ready!"
|
||||||
exec s6-svscan /etc/s6/
|
exec s6-svscan /etc/s6/
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ http {
|
|||||||
|
|
||||||
server {
|
server {
|
||||||
listen 80;
|
listen 80;
|
||||||
|
listen [::0]:80;
|
||||||
server_name _;
|
server_name _;
|
||||||
root /var/www/wallabag/web;
|
root /var/www/wallabag/web;
|
||||||
|
|
||||||
@@ -57,6 +58,7 @@ http {
|
|||||||
# for more information).
|
# for more information).
|
||||||
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
|
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
|
||||||
fastcgi_param DOCUMENT_ROOT $realpath_root;
|
fastcgi_param DOCUMENT_ROOT $realpath_root;
|
||||||
|
fastcgi_read_timeout 300s;
|
||||||
# Prevents URIs that include the front controller. This will 404:
|
# Prevents URIs that include the front controller. This will 404:
|
||||||
# http://domain.tld/app.php/some-path
|
# http://domain.tld/app.php/some-path
|
||||||
# Remove the internal directive to allow URIs like this
|
# Remove the internal directive to allow URIs like this
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -5,20 +5,14 @@ parameters:
|
|||||||
database_name: ${SYMFONY__ENV__DATABASE_NAME:-symfony}
|
database_name: ${SYMFONY__ENV__DATABASE_NAME:-symfony}
|
||||||
database_user: ${SYMFONY__ENV__DATABASE_USER:-root}
|
database_user: ${SYMFONY__ENV__DATABASE_USER:-root}
|
||||||
database_password: ${SYMFONY__ENV__DATABASE_PASSWORD:-~}
|
database_password: ${SYMFONY__ENV__DATABASE_PASSWORD:-~}
|
||||||
database_path: "%kernel.root_dir%/../data/db/wallabag.sqlite"
|
database_path: "%kernel.project_dir%/data/db/wallabag.sqlite"
|
||||||
database_table_prefix: ${SYMFONY__ENV__DATABASE_TABLE_PREFIX:-wallabag_}
|
database_table_prefix: ${SYMFONY__ENV__DATABASE_TABLE_PREFIX:-wallabag_}
|
||||||
database_socket: null
|
database_socket: null
|
||||||
database_charset: ${SYMFONY__ENV__DATABASE_CHARSET:-utf8}
|
database_charset: ${SYMFONY__ENV__DATABASE_CHARSET:-utf8}
|
||||||
|
|
||||||
domain_name: ${SYMFONY__ENV__DOMAIN_NAME:-https://your-wallabag-url-instance.com}
|
domain_name: ${SYMFONY__ENV__DOMAIN_NAME:-https://your-wallabag-instance.wallabag.org}
|
||||||
|
|
||||||
mailer_transport: ${SYMFONY__ENV__MAILER_TRANSPORT:-smtp}
|
mailer_dsn: ${SYMFONY__ENV__MAILER_DSN:-smtp://127.0.0.1}
|
||||||
mailer_user: ${SYMFONY__ENV__MAILER_USER:-~}
|
|
||||||
mailer_password: ${SYMFONY__ENV__MAILER_PASSWORD:-~}
|
|
||||||
mailer_host: ${SYMFONY__ENV__MAILER_HOST:-127.0.0.1}
|
|
||||||
mailer_port: ${SYMFONY__ENV__MAILER_PORT:-25}
|
|
||||||
mailer_encryption: ${SYMFONY__ENV__MAILER_ENCRYPTION:-~}
|
|
||||||
mailer_auth_mode: ${SYMFONY__ENV__MAILER_AUTH_MODE:-~}
|
|
||||||
|
|
||||||
locale: ${SYMFONY__ENV__LOCALE:-en}
|
locale: ${SYMFONY__ENV__LOCALE:-en}
|
||||||
|
|
||||||
@@ -26,11 +20,10 @@ parameters:
|
|||||||
secret: ${SYMFONY__ENV__SECRET:-ovmpmAWXRCabNlMgzlzFXDYmCFfzGv}
|
secret: ${SYMFONY__ENV__SECRET:-ovmpmAWXRCabNlMgzlzFXDYmCFfzGv}
|
||||||
|
|
||||||
# two factor stuff
|
# two factor stuff
|
||||||
twofactor_auth: ${SYMFONY__ENV__TWOFACTOR_AUTH:-true}
|
|
||||||
twofactor_sender: ${SYMFONY__ENV__TWOFACTOR_SENDER:-no-reply@wallabag.org}
|
twofactor_sender: ${SYMFONY__ENV__TWOFACTOR_SENDER:-no-reply@wallabag.org}
|
||||||
|
|
||||||
# fosuser stuff
|
# fosuser stuff
|
||||||
fosuser_registration: ${SYMFONY__ENV__FOSUSER_REGISTRATION:-true}
|
fosuser_registration: ${SYMFONY__ENV__FOSUSER_REGISTRATION:-false}
|
||||||
fosuser_confirmation: ${SYMFONY__ENV__FOSUSER_CONFIRMATION:-true}
|
fosuser_confirmation: ${SYMFONY__ENV__FOSUSER_CONFIRMATION:-true}
|
||||||
|
|
||||||
# how long the access token should live in seconds for the API
|
# how long the access token should live in seconds for the API
|
||||||
|
|||||||
1
root/etc/wallabag/php-wallabag.template.ini
Normal file
1
root/etc/wallabag/php-wallabag.template.ini
Normal file
@@ -0,0 +1 @@
|
|||||||
|
memory_limit = ${PHP_MEMORY_LIMIT:-128M}
|
||||||
@@ -18,6 +18,6 @@ services:
|
|||||||
- "127.0.0.1:80:80"
|
- "127.0.0.1:80:80"
|
||||||
db:
|
db:
|
||||||
image: mariadb
|
image: mariadb
|
||||||
command: mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --character-set-client-handshake=FALSE
|
command: mariadbd --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --character-set-client-handshake=FALSE
|
||||||
environment:
|
environment:
|
||||||
- MYSQL_ROOT_PASSWORD=wallaroot
|
- MYSQL_ROOT_PASSWORD=wallaroot
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ services:
|
|||||||
- SYMFONY__ENV__DATABASE_PORT=~
|
- SYMFONY__ENV__DATABASE_PORT=~
|
||||||
- SYMFONY__ENV__DATABASE_NAME=symfony
|
- SYMFONY__ENV__DATABASE_NAME=symfony
|
||||||
- SYMFONY__ENV__DATABASE_USER=root
|
- SYMFONY__ENV__DATABASE_USER=root
|
||||||
- SYMFONY__ENV_DATABASE_PASSWORD=~
|
- SYMFONY__ENV__DATABASE_PASSWORD=~
|
||||||
- SYMFONY__ENV__SECRET=F00B4R
|
- SYMFONY__ENV__SECRET=F00B4R
|
||||||
ports:
|
ports:
|
||||||
- "127.0.0.1:80:80"
|
- "127.0.0.1:80:80"
|
||||||
|
|||||||
@@ -1,24 +1,63 @@
|
|||||||
import pytest
|
import pytest
|
||||||
import re
|
import re
|
||||||
import requests
|
import requests
|
||||||
|
import os
|
||||||
|
|
||||||
|
from requests.exceptions import ConnectionError
|
||||||
|
|
||||||
URL = 'http://127.0.0.1:80'
|
@pytest.fixture(scope="session")
|
||||||
|
def database(pytestconfig):
|
||||||
|
return pytestconfig.getoption("database")
|
||||||
|
|
||||||
|
def is_responsive(url):
|
||||||
|
try:
|
||||||
|
response = requests.get(url)
|
||||||
|
if response.status_code == 200:
|
||||||
|
return True
|
||||||
|
except ConnectionError:
|
||||||
|
return False
|
||||||
|
|
||||||
def test_accessing_login_page():
|
@pytest.fixture(scope="session")
|
||||||
r = requests.get(URL, allow_redirects=True)
|
def docker_compose_project_name(database):
|
||||||
|
return "wallabag_{}".format(database)
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
def docker_cleanup():
|
||||||
|
"""Disable docker cleanup at the end of tests to get logs outside of pytest"""
|
||||||
|
return False
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
def docker_compose_command() -> str:
|
||||||
|
return "docker-compose"
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
def docker_compose_file(pytestconfig, database):
|
||||||
|
return os.path.join(str(pytestconfig.rootdir), "tests/", "docker-compose.{}.yml".format(database))
|
||||||
|
|
||||||
|
@pytest.fixture(scope="session")
|
||||||
|
def wallabag_service(docker_ip, docker_services):
|
||||||
|
"""Ensure that wallabag service is up and responsive"""
|
||||||
|
|
||||||
|
# `port_for` takes a container port and returns the corresponding host port
|
||||||
|
port = docker_services.port_for("wallabag", 80)
|
||||||
|
url = "http://{}:{}".format(docker_ip, port)
|
||||||
|
docker_services.wait_until_responsive(
|
||||||
|
timeout=60.0, pause=0.5, check=lambda: is_responsive(url)
|
||||||
|
)
|
||||||
|
return url
|
||||||
|
|
||||||
|
def test_accessing_login_page(wallabag_service):
|
||||||
|
r = requests.get(wallabag_service, allow_redirects=True)
|
||||||
|
|
||||||
assert r.status_code == 200
|
assert r.status_code == 200
|
||||||
assert 'Log in' in r.text
|
assert 'Log in' in r.text
|
||||||
assert 'Password' in r.text
|
assert 'Password' in r.text
|
||||||
assert 'Register' in r.text
|
|
||||||
assert 'Username' in r.text
|
assert 'Username' in r.text
|
||||||
|
|
||||||
|
|
||||||
def test_logging_in():
|
def test_logging_in(wallabag_service):
|
||||||
client = requests.session()
|
client = requests.session()
|
||||||
r = client.get(URL, allow_redirects=True)
|
r = client.get(wallabag_service, allow_redirects=True)
|
||||||
jar = r.cookies
|
jar = r.cookies
|
||||||
|
|
||||||
# get csrf token
|
# get csrf token
|
||||||
@@ -39,7 +78,7 @@ def test_logging_in():
|
|||||||
'_csrf_token': csrf
|
'_csrf_token': csrf
|
||||||
}
|
}
|
||||||
|
|
||||||
r = client.post(URL + '/login_check', cookies=jar, data=data)
|
r = client.post(wallabag_service + '/login_check', cookies=jar, data=data)
|
||||||
assert r.status_code == 200
|
assert r.status_code == 200
|
||||||
assert '/unread/list' in r.text
|
assert '/unread/list' in r.text
|
||||||
assert '/starred/list' in r.text
|
assert '/starred/list' in r.text
|
||||||
|
|||||||
Reference in New Issue
Block a user