82931684eb
CI / Test (server-http) (pull_request) Successful in 21s
CI / Test (rest) (pull_request) Successful in 23s
CI / Test (store) (pull_request) Successful in 36s
CI / Lint (pull_request) Successful in 27s
CI / Build (windows/amd64) (pull_request) Successful in 26s
CI / Build (linux/arm64) (pull_request) Successful in 23s
CI / Build (linux/amd64) (pull_request) Successful in 1m24s
e2e / Playwright vs docker-compose (pull_request) Failing after 2m52s
P5-01 — Documentation site under docs/book/ rendered with mdBook
(downloaded via Makefile, same static-binary pattern as Tailwind).
Structured chapters: getting started, concepts, operations,
security, reference. `make docs` / `make docs-watch`. Generated
output gitignored.
P5-02 — CONTRIBUTING.md rewritten from placeholder to a full
guide. CODE_OF_CONDUCT.md adapted from Contributor Covenant for a
single-maintainer project. .gitea/issue_template/{bug,feature}.md
and PULL_REQUEST_TEMPLATE.md.
P5-04 — Six README screenshots captured live from a fresh server
bootstrap (login, empty dashboard, add-host, alerts, settings,
audit log). README rewritten to centre the screenshot grid and
link out to the docs site.
P5-05 — SECURITY.md with disclosure policy (3-day ack, 30-day
default window), scope in/out, threat-model summary, operator
hardening checklist. Mirrored as a docs-site chapter.
P5-06 — End-to-end test harness. e2e/compose.e2e.yml brings up
server + sibling Linux agent (alpine + restic) + restic/rest-server.
Agent uses announce-and-approve so Playwright can drive the full
operator flow: bootstrap → login → accept pending → backup →
verify terminal status. Second spec scrapes /metrics to assert
the P6-04 endpoint surface. .gitea/workflows/e2e.yml runs on every
PR; local how-to in docs/e2e.md.
88 lines
2.3 KiB
YAML
88 lines
2.3 KiB
YAML
# End-to-end test stack — used by .gitea/workflows/e2e.yml and by
|
|
# operators who want to run the Playwright suite locally.
|
|
#
|
|
# Three services:
|
|
# * server — restic-manager built from the working tree
|
|
# * agent — restic-manager agent built from the working tree
|
|
# (announces; Playwright accepts it during the test)
|
|
# * rest-server — the actual restic backend, sibling of the agent
|
|
#
|
|
# Run from the repo root:
|
|
# docker compose -f e2e/compose.e2e.yml up --build --abort-on-container-exit
|
|
|
|
services:
|
|
rest-server:
|
|
image: restic/rest-server:0.13.0
|
|
environment:
|
|
DATA_DIR: /data
|
|
OPTIONS: "--no-auth"
|
|
volumes:
|
|
- rest-data:/data
|
|
networks: [rmnet]
|
|
|
|
server:
|
|
build:
|
|
context: ..
|
|
dockerfile: deploy/Dockerfile.server
|
|
args:
|
|
VERSION: e2e
|
|
environment:
|
|
RM_LISTEN: ":8080"
|
|
RM_DATA_DIR: "/data"
|
|
RM_BASE_URL: "http://server:8080"
|
|
RM_COOKIE_SECURE: "false"
|
|
# Bind the metrics endpoint loose for the test, so one of the
|
|
# Playwright assertions can exercise it.
|
|
RM_METRICS_TRUSTED_CIDR: "0.0.0.0/0"
|
|
volumes:
|
|
- server-data:/data
|
|
ports:
|
|
- "127.0.0.1:8080:8080"
|
|
healthcheck:
|
|
test: ["CMD", "/usr/local/bin/restic-manager-server", "--version"]
|
|
interval: 2s
|
|
timeout: 2s
|
|
retries: 30
|
|
networks: [rmnet]
|
|
|
|
agent:
|
|
build:
|
|
context: ..
|
|
dockerfile: e2e/Dockerfile.agent
|
|
args:
|
|
VERSION: e2e
|
|
environment:
|
|
RM_SERVER: "http://server:8080"
|
|
depends_on:
|
|
- server
|
|
volumes:
|
|
# Source paths the agent backs up. Compose pre-populates this
|
|
# with a few files so the snapshot list isn't empty.
|
|
- source-data:/source
|
|
- agent-config:/etc/restic-manager
|
|
- agent-state:/var/lib/restic-manager-agent
|
|
networks: [rmnet]
|
|
|
|
# One-shot init container that drops a couple of files into the
|
|
# source volume so backups have something to snapshot.
|
|
source-fixture:
|
|
image: alpine:3.20
|
|
command: >
|
|
sh -c 'mkdir -p /source && echo "hello world" > /source/hello.txt &&
|
|
echo "another file" > /source/two.txt && sleep 0.2'
|
|
volumes:
|
|
- source-data:/source
|
|
networks: [rmnet]
|
|
restart: "no"
|
|
|
|
volumes:
|
|
server-data:
|
|
rest-data:
|
|
source-data:
|
|
agent-config:
|
|
agent-state:
|
|
|
|
networks:
|
|
rmnet:
|
|
driver: bridge
|