Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 65d03e376d | |||
| cc6194c048 | |||
| 2ebe6ba51c | |||
| d3319d2202 |
65
.drone.yml
65
.drone.yml
@@ -12,21 +12,32 @@ trigger:
|
|||||||
- pull_request
|
- pull_request
|
||||||
|
|
||||||
environment:
|
environment:
|
||||||
GOPRIVATE: git.beatrice.wtf/panic.haus/*
|
GOPROXY: https://git.beatrice.wtf/api/packages/panic.haus/go,https://proxy.golang.org,direct
|
||||||
GONOSUMDB: git.beatrice.wtf/panic.haus/*
|
GONOSUMDB: git.beatrice.wtf
|
||||||
|
GONOSUMCHECK: git.beatrice.wtf
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: test
|
- name: test
|
||||||
image: golang:1.26
|
image: golang:1.26
|
||||||
|
volumes:
|
||||||
|
- name: go-mod-cache
|
||||||
|
path: /go/pkg/mod
|
||||||
commands:
|
commands:
|
||||||
- go mod download
|
- go mod download
|
||||||
- go test ./... -count=1
|
- go test ./... -count=1
|
||||||
|
|
||||||
- name: build
|
- name: build
|
||||||
image: golang:1.26
|
image: golang:1.26
|
||||||
|
volumes:
|
||||||
|
- name: go-mod-cache
|
||||||
|
path: /go/pkg/mod
|
||||||
commands:
|
commands:
|
||||||
- go build ./...
|
- go build ./...
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
- name: go-mod-cache
|
||||||
|
temp: {}
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
@@ -39,22 +50,64 @@ trigger:
|
|||||||
- refs/tags/v*
|
- refs/tags/v*
|
||||||
|
|
||||||
environment:
|
environment:
|
||||||
GOPRIVATE: git.beatrice.wtf/panic.haus/*
|
GOPROXY: https://git.beatrice.wtf/api/packages/panic.haus/go,https://proxy.golang.org,direct
|
||||||
GONOSUMDB: git.beatrice.wtf/panic.haus/*
|
GONOSUMDB: git.beatrice.wtf
|
||||||
|
GONOSUMCHECK: git.beatrice.wtf
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: test
|
- name: test
|
||||||
image: golang:1.26
|
image: golang:1.26
|
||||||
|
volumes:
|
||||||
|
- name: go-mod-cache
|
||||||
|
path: /go/pkg/mod
|
||||||
commands:
|
commands:
|
||||||
- go mod download
|
- go mod download
|
||||||
- go test ./... -count=1
|
- go test ./... -count=1
|
||||||
|
|
||||||
- name: build
|
- name: build
|
||||||
image: golang:1.26
|
image: golang:1.26
|
||||||
|
volumes:
|
||||||
|
- name: go-mod-cache
|
||||||
|
path: /go/pkg/mod
|
||||||
commands:
|
commands:
|
||||||
- go build ./...
|
- go build ./...
|
||||||
|
|
||||||
- name: warm-proxy
|
- name: publish
|
||||||
image: golang:1.26
|
image: golang:1.26
|
||||||
|
environment:
|
||||||
|
GITEA_TOKEN:
|
||||||
|
from_secret: gitea_token
|
||||||
commands:
|
commands:
|
||||||
- go list -m git.beatrice.wtf/panic.haus/go-core@${DRONE_TAG}
|
- apt-get update -q && apt-get install -qy python3
|
||||||
|
- MODULE=$(go mod edit -json | python3 -c "import json,sys; print(json.load(sys.stdin)['Module']['Path'])")
|
||||||
|
- VERSION=${DRONE_TAG}
|
||||||
|
- echo "Publishing $MODULE@$VERSION"
|
||||||
|
- go mod download
|
||||||
|
- |
|
||||||
|
cat > /tmp/mkzip.py << 'PYEOF'
|
||||||
|
import zipfile, os, sys
|
||||||
|
module, version = sys.argv[1], sys.argv[2]
|
||||||
|
prefix = f'{module}@{version}/'
|
||||||
|
with zipfile.ZipFile('/tmp/module.zip', 'w', zipfile.ZIP_DEFLATED) as zf:
|
||||||
|
for root, dirs, files in os.walk('.'):
|
||||||
|
dirs[:] = [d for d in dirs if not d.startswith('.')]
|
||||||
|
for f in files:
|
||||||
|
if f.startswith('.'): continue
|
||||||
|
path = os.path.join(root, f)
|
||||||
|
zf.write(path, prefix + os.path.relpath(path, '.'))
|
||||||
|
print(f'Zip created: {len(zf.namelist())} files')
|
||||||
|
PYEOF
|
||||||
|
- python3 /tmp/mkzip.py "$MODULE" "$VERSION"
|
||||||
|
- |
|
||||||
|
HTTP_CODE=$(curl -s -o /dev/null -w "%{http_code}" -X PUT \
|
||||||
|
"https://git.beatrice.wtf/api/packages/panic.haus/go/upload" \
|
||||||
|
-H "Authorization: token $GITEA_TOKEN" \
|
||||||
|
-H "Content-Type: application/zip" \
|
||||||
|
--data-binary "@/tmp/module.zip")
|
||||||
|
echo "Upload HTTP $HTTP_CODE"
|
||||||
|
[ "$HTTP_CODE" = "201" ] || exit 1
|
||||||
|
- echo "Published $MODULE@$VERSION to Gitea package registry"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
- name: go-mod-cache
|
||||||
|
temp: {}
|
||||||
|
|||||||
Reference in New Issue
Block a user