feat: run forgejo service in CI
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
ci/woodpecker/pr/woodpecker Pipeline failed

This commit is contained in:
Aravinth Manivannan 2025-01-02 17:57:26 +05:30
parent ab8355ea24
commit c637ffe344
Signed by: realaravinth
GPG key ID: F8F50389936984FF
4 changed files with 27 additions and 9 deletions

View file

@ -1,4 +1,15 @@
steps: steps:
setup:
image: python
when:
event: [push, pull_request, tag, deployment]
environment:
POSTGRES_DATABASE_URL: postgres://postgres:password@database:5432/postgres
commands:
- sed -i 's/localhost/forgejo/' scripts/gitea.py
- python ./scripts/gitea.py
test: test:
image: rust image: rust
when: when:
@ -17,7 +28,7 @@ steps:
- make migrate - make migrate
- make - make
# - make lint # - make lint
- make test - make test.workspaces
build_docker_img: build_docker_img:
@ -30,6 +41,9 @@ steps:
tags: latest tags: latest
services: services:
forgejo:
image: codeberg.org/forgejo/forgejo:9
database: database:
image: postgres image: postgres
environment: environment:

View file

@ -131,6 +131,10 @@ test: migrate ## Run tests
$(call cache_bust) $(call cache_bust)
$(call test_workspaces) $(call test_workspaces)
test.workspaces:
$(call cache_bust)
$(call test_workspaces)
# cd database/db-sqlx-postgres &&\ # cd database/db-sqlx-postgres &&\
# DATABASE_URL=${POSTGRES_DATABASE_URL}\ # DATABASE_URL=${POSTGRES_DATABASE_URL}\
# cargo test --no-fail-fast # cargo test --no-fail-fast

View file

@ -19,5 +19,5 @@ services:
- /etc/timezone:/etc/timezone:ro - /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro - /etc/localtime:/etc/localtime:ro
ports: ports:
- "8080:3000" - "3000:3000"
- "2221:22" - "2221:22"

View file

@ -20,7 +20,7 @@ def check_online():
while True: while True:
try: try:
res = requests.get( res = requests.get(
"http://localhost:8080/api/v1/nodeinfo", allow_redirects=False "http://localhost:3000/api/v1/nodeinfo", allow_redirects=False
) )
if any([res.status_code == 302, res.status_code == 200]): if any([res.status_code == 302, res.status_code == 200]):
break break
@ -49,7 +49,7 @@ def install():
"domain": "localhost", "domain": "localhost",
"ssh_port": "2221", "ssh_port": "2221",
"http_port": "3000", "http_port": "3000",
"app_url": "http://localhost:8080/", "app_url": "http://localhost:3000/",
"log_root_path": "/data/gitea/log", "log_root_path": "/data/gitea/log",
"smtp_host": "", "smtp_host": "",
"smtp_from": "", "smtp_from": "",
@ -67,7 +67,7 @@ def install():
"admin_confirm_passwd": "", "admin_confirm_passwd": "",
"admin_email": "", "admin_email": "",
} }
requests.post(f"http://localhost:8080", data=INSTALL_PAYLOAD) requests.post(f"http://localhost:3000", data=INSTALL_PAYLOAD)
class ParseCSRFGiteaForm(HTMLParser): class ParseCSRFGiteaForm(HTMLParser):
@ -118,7 +118,7 @@ class HTMLClient:
def register(client: HTMLClient): def register(client: HTMLClient):
url = "http://localhost:8080/user/sign_up" url = "http://localhost:3000/user/sign_up"
csrf = client.get_csrf_token(url) csrf = client.get_csrf_token(url)
payload = { payload = {
"_csrf": csrf, "_csrf": csrf,
@ -131,7 +131,7 @@ def register(client: HTMLClient):
def login(client: HTMLClient): def login(client: HTMLClient):
url = "http://localhost:8080/user/login" url = "http://localhost:3000/user/login"
csrf = client.get_csrf_token(url) csrf = client.get_csrf_token(url)
payload = { payload = {
"_csrf": csrf, "_csrf": csrf,
@ -167,7 +167,7 @@ def create_repositories(client: HTMLClient):
} }
return data return data
url = "http://localhost:8080/repo/create" url = "http://localhost:3000/repo/create"
for repo in REPOS: for repo in REPOS:
csrf = client.get_csrf_token(url) csrf = client.get_csrf_token(url)
resp = client.session.post(url, data=get_repository_payload(csrf, repo)) resp = client.session.post(url, data=get_repository_payload(csrf, repo))
@ -182,7 +182,7 @@ def create_repositories(client: HTMLClient):
def add_tag(repo: str, client: HTMLClient): def add_tag(repo: str, client: HTMLClient):
print("adding tags") print("adding tags")
tag = "testing" tag = "testing"
url = f"http://{GITEA_USER}:{GITEA_PASSWORD}@localhost:8080/api/v1/repos/{GITEA_USER}/{repo}/topics/{tag}" url = f"http://{GITEA_USER}:{GITEA_PASSWORD}@localhost:3000/api/v1/repos/{GITEA_USER}/{repo}/topics/{tag}"
resp = requests.put(url) resp = requests.put(url)
if resp.status_code != 204: if resp.status_code != 204:
print(f"Error while adding tags repository: {repo} {resp.status_code}") print(f"Error while adding tags repository: {repo} {resp.status_code}")