mirror of
https://github.com/wallabag/docker.git
synced 2025-12-21 19:27:35 +01:00
Compare commits
38 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 96dd9bc3e3 | |||
| 5bde344da3 | |||
| 36d4bf58db | |||
| e7b0f9c7f6 | |||
| 5a426ce3fa | |||
| 75d1b96cc8 | |||
| b340aaee0a | |||
| 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 |
21
.github/workflows/test.yml
vendored
21
.github/workflows/test.yml
vendored
@ -36,17 +36,16 @@ jobs:
|
||||
- name: "Build image"
|
||||
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"
|
||||
run: pip install pytest requests
|
||||
|
||||
- name: "Check running instance"
|
||||
run: docker ps
|
||||
|
||||
- name: "Wait 60s"
|
||||
run: sleep 60
|
||||
run: pip install pytest pytest-docker requests
|
||||
|
||||
- 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
|
||||
|
||||
23
Dockerfile
23
Dockerfile
@ -1,3 +1,7 @@
|
||||
ARG COMPOSER_VERSION=2.5.8
|
||||
|
||||
FROM composer:$COMPOSER_VERSION as composer
|
||||
|
||||
FROM golang:alpine as builder
|
||||
|
||||
# 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
|
||||
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
|
||||
|
||||
ARG WALLABAG_VERSION=2.6.1
|
||||
ARG WALLABAG_VERSION=2.6.4
|
||||
|
||||
RUN set -ex \
|
||||
&& apk add --no-cache \
|
||||
@ -30,6 +34,7 @@ RUN set -ex \
|
||||
php81-mbstring \
|
||||
php81-openssl \
|
||||
php81-pecl-amqp \
|
||||
php81-pecl-imagick \
|
||||
php81-pdo_mysql \
|
||||
php81-pdo_pgsql \
|
||||
php81-pdo_sqlite \
|
||||
@ -54,15 +59,14 @@ RUN set -ex \
|
||||
&& ln -sf /usr/sbin/php-fpm81 /usr/sbin/php-fpm \
|
||||
&& rm -rf /var/cache/apk/* \
|
||||
&& ln -sf /dev/stdout /var/log/nginx/access.log \
|
||||
&& ln -sf /dev/stderr /var/log/nginx/error.log \
|
||||
&& curl -s https://getcomposer.org/installer | php \
|
||||
&& mv composer.phar /usr/local/bin/composer \
|
||||
&& rm -rf /root/.composer/*
|
||||
&& ln -sf /dev/stderr /var/log/nginx/error.log
|
||||
|
||||
COPY --from=composer /usr/bin/composer /usr/local/bin/composer
|
||||
|
||||
COPY root /
|
||||
|
||||
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 \
|
||||
&& mkdir /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/* \
|
||||
&& chown -R nobody:nobody /var/www/wallabag
|
||||
|
||||
ENV PATH="${PATH}:/var/www/wallabag/bin"
|
||||
|
||||
# Set console entry path
|
||||
WORKDIR /var/www/wallabag
|
||||
|
||||
EXPOSE 80
|
||||
ENTRYPOINT ["/entrypoint.sh"]
|
||||
CMD ["wallabag"]
|
||||
|
||||
@ -29,9 +29,8 @@ Default login is `wallabag:wallabag`.
|
||||
- `-e SYMFONY__ENV__LOCALE=...` (default to en)
|
||||
- `-e SYMFONY__ENV__MAILER_DSN=...` (defaults to "smtp://127.0.0.1")
|
||||
- `-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__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__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))
|
||||
|
||||
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")
|
||||
@ -5,7 +5,7 @@ parameters:
|
||||
database_name: ${SYMFONY__ENV__DATABASE_NAME:-symfony}
|
||||
database_user: ${SYMFONY__ENV__DATABASE_USER:-root}
|
||||
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_socket: null
|
||||
database_charset: ${SYMFONY__ENV__DATABASE_CHARSET:-utf8}
|
||||
@ -20,11 +20,10 @@ parameters:
|
||||
secret: ${SYMFONY__ENV__SECRET:-ovmpmAWXRCabNlMgzlzFXDYmCFfzGv}
|
||||
|
||||
# two factor stuff
|
||||
twofactor_auth: ${SYMFONY__ENV__TWOFACTOR_AUTH:-true}
|
||||
twofactor_sender: ${SYMFONY__ENV__TWOFACTOR_SENDER:-no-reply@wallabag.org}
|
||||
|
||||
# fosuser stuff
|
||||
fosuser_registration: ${SYMFONY__ENV__FOSUSER_REGISTRATION:-true}
|
||||
fosuser_registration: ${SYMFONY__ENV__FOSUSER_REGISTRATION:-false}
|
||||
fosuser_confirmation: ${SYMFONY__ENV__FOSUSER_CONFIRMATION:-true}
|
||||
|
||||
# how long the access token should live in seconds for the API
|
||||
|
||||
@ -1,24 +1,63 @@
|
||||
import pytest
|
||||
import re
|
||||
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():
|
||||
r = requests.get(URL, allow_redirects=True)
|
||||
@pytest.fixture(scope="session")
|
||||
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 'Log in' in r.text
|
||||
assert 'Password' in r.text
|
||||
assert 'Register' in r.text
|
||||
assert 'Username' in r.text
|
||||
|
||||
|
||||
def test_logging_in():
|
||||
def test_logging_in(wallabag_service):
|
||||
client = requests.session()
|
||||
r = client.get(URL, allow_redirects=True)
|
||||
r = client.get(wallabag_service, allow_redirects=True)
|
||||
jar = r.cookies
|
||||
|
||||
# get csrf token
|
||||
@ -39,7 +78,7 @@ def test_logging_in():
|
||||
'_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 '/unread/list' in r.text
|
||||
assert '/starred/list' in r.text
|
||||
|
||||
Reference in New Issue
Block a user