0
Fork 0
mirror of https://codeberg.org/librewolf/source.git synced 2025-01-24 05:08:48 -05:00

Add woodpecker

This commit is contained in:
Bert van der Weerd 2023-08-17 19:56:16 +02:00
parent d859ec9293
commit 7b93d7e2c9
No known key found for this signature in database
GPG key ID: 73370A0B9E5516B0
6 changed files with 230 additions and 4 deletions

View file

@ -0,0 +1,17 @@
{
"name": "codeberg-release-tool",
"version": "0.1.0",
"license": "Apache-2.0",
"scripts": {
"build": "tsc",
"start": "node dist/release.js"
},
"dependencies": {
"axios": "^0.21.1",
"form-data": "^4.0.0"
},
"devDependencies": {
"@types/node": "^20.5.0",
"typescript": "^4.2.4"
}
}

View file

@ -0,0 +1,113 @@
import axios from 'axios';
import fs from 'fs';
import path from 'path';
import FormData from 'form-data';
// Environment Variables:
// CB_API_KEY: The API key for accessing Codeberg.
// TODO: change this to match
const repoUrl = 'https://codeberg.org/api/v1/repos/threadpanic/cb-src-woodpecker';
// Extract the command-line argument and assign to 'version'
const version = process.argv[2];
if (!version) {
console.error('Please provide the version as a command-line argument.');
process.exit(1);
}
const tarball_artifact = `librewolf-${version}.source.tar.gz`;
const sha256sum_artifact = `${tarball_artifact}.sha256sum`;
const tarballExists = fs.existsSync(path.join('..', tarball_artifact));
const sha256sumExists = fs.existsSync(path.join('..', sha256sum_artifact));
if (!tarballExists || !sha256sumExists) {
console.error(`Missing artifacts. Ensure both ${tarball_artifact} and ${sha256sum_artifact} are present in the parent directory.`);
process.exit(1);
}
const apiKey = process.env.CB_API_KEY;
if (!apiKey) {
console.error('API key not found in environment variable CB_API_KEY.');
process.exit(1);
}
const headers = {
'Authorization': `Bearer ${apiKey}`
};
async function addReleaseArtifact(fileName: string, releaseId: number) {
const apiUrl = `${repoUrl}/releases/${releaseId}/assets?name=${fileName}`;
const formData = new FormData();
formData.append('attachment', fs.createReadStream(path.join('..', fileName)));
try {
const response = await axios.post(apiUrl, formData, {
headers: {
...headers,
...formData.getHeaders()
}
});
if (response.status !== 201) {
throw new Error(`Failed to attach artifact ${fileName}. Unexpected response status: ${response.status}`);
}
} catch (error: any) {
console.error(`Error while attaching artifact ${fileName}:`, error.response ? error.response.data : error.message);
throw error;
}
}
async function createNewRelease() {
const releaseUrl = `${repoUrl}/releases`;
const requestBody = {
body: `Release v${version} of the LibreWolf source tarball. Please see the README.md file for compilation instructions and dependency details.`,
draft: false,
name: `Release ${version}`,
prerelease: false,
tag_name: `v${version}`
};
try {
const response = await axios.post(releaseUrl, requestBody, { headers: headers });
if (response.status === 201) {
await addReleaseArtifact(tarball_artifact, response.data.id);
await addReleaseArtifact(sha256sum_artifact, response.data.id);
} else {
throw new Error(`Failed to create release. Unexpected response status: ${response.status}`);
}
} catch (error: any) {
console.error("Error while creating release:", error.response ? error.response.data : error.message);
throw error;
}
}
async function main() {
try {
const releaseListResponse = await axios.get(`${repoUrl}/releases`);
if (releaseListResponse.data.length === 0) {
await createNewRelease();
} else {
const latestReleaseResponse = await axios.get(`${repoUrl}/releases/latest`);
if (latestReleaseResponse.data.tag_name === `v${version}`) {
console.log(`Version v${version} already exists as a release. Exiting without creating a new release.`);
process.exit(0);
}
await createNewRelease();
}
process.exit(0);
} catch (error: any) {
console.error('Error while processing releases:', error);
process.exit(1);
}
}
main();

View file

@ -0,0 +1,17 @@
{
"compilerOptions": {
"target": "ES2020",
"module": "commonjs",
"strict": true,
"esModuleInterop": true,
"skipLibCheck": true,
"forceConsistentCasingInFileNames": true,
"outDir": "./dist"
},
"include": [
"release.ts"
],
"exclude": [
"node_modules"
]
}

57
.woodpecker.yml Normal file
View file

@ -0,0 +1,57 @@
steps:
fetch:
image: alpine
commands:
- apk update -U
- apk add make gnupg
- make fetch-upstream-woodpecker
test:
image: alpine
commands:
- apk update -U
- apk add make patch
- make check-patchfail-woodpecker
build:
image: alpine
commands:
- apk update -U
- apk add make gnupg patch python3 bash xz
- make all
#
# release:
# image: alpine
# commands:
# - apk update -U
# - apk add nodejs npm
#
# - ( cd .woodpecker.release && npm install && npm run build )
# - ( cd .woodpecker.release && npm run start $(cat ../version)-$(cat ../release) )
#
# secrets: [ cb_api_key ]
#
upload:
image: woodpeckerci/plugin-s3
settings:
bucket: artifacts
source: "*.{tar.gz,sha256sum}"
target: /${CI_BUILD_NUMBER}
path_style: true
endpoint: https://storage.ci.librewolf.net
secrets: [aws_access_key_id, aws_secret_access_key]
display-links:
image: alpine
commands:
- echo "https://storage.ci.librewolf.net/artifacts/${CI_BUILD_NUMBER}/librewolf-$(cat version)-$(cat release).source.tar.gz"
- echo "https://storage.ci.librewolf.net/artifacts/${CI_BUILD_NUMBER}/librewolf-$(cat version)-$(cat release).source.tar.gz.sha256sum"

View file

@ -1,6 +1,6 @@
docker_targets=docker-build-image docker-run-build-job docker-remove-image docker_targets=docker-build-image docker-run-build-job docker-remove-image
woodpecker_targets=fetch-upstream-woodpecker check-patchfail-woodpecker
.PHONY : help check all clean veryclean dir bootstrap fetch build package run update setup-wasi check-patchfail check-fuzz fixfuzz $(docker_targets) .PHONY : help check all clean veryclean dir bootstrap fetch build package run update setup-wasi check-patchfail check-fuzz fixfuzz $(docker_targets) $(woodpecker_targets)
version:=$(shell cat ./version) version:=$(shell cat ./version)
release:=$(shell cat ./release) release:=$(shell cat ./release)
@ -93,12 +93,15 @@ $(lw_source_dir) : $(ff_source_tarball) ./version ./release scripts/librewolf-pa
$(lw_source_tarball) : $(lw_source_dir) $(lw_source_tarball) : $(lw_source_dir)
rm -f $(lw_source_tarball) rm -f $(lw_source_tarball)
$(archive_create) $(lw_source_tarball) $(lw_source_dir) tar cf librewolf-$(version)-$(release).source.tar $(lw_source_dir)
time gzip --fast librewolf-$(version)-$(release).source.tar
touch $(lw_source_dir) touch $(lw_source_dir)
sha256sum $(lw_source_tarball) > $(lw_source_tarball).sha256sum sha256sum $(lw_source_tarball) > $(lw_source_tarball).sha256sum
cat $(lw_source_tarball).sha256sum cat $(lw_source_tarball).sha256sum
sha256sum -c $(lw_source_tarball).sha256sum
[ "$(SIGNING_KEY)" != "" ] && cp -v $(SIGNING_KEY) pk.asc ; true [ "$(SIGNING_KEY)" != "" ] && cp -v $(SIGNING_KEY) pk.asc ; true
if [ -f pk.asc ]; then gpg --import pk.asc; gpg --detach-sign $(lw_source_tarball) && ls -lh $(lw_source_tarball).sig; fi if [ -f pk.asc ]; then gpg --import pk.asc; gpg --detach-sign $(lw_source_tarball) && ls -lh $(lw_source_tarball).sig; fi
ls -lh $(lw_source_tarball)*
debs=python3 python3-dev python3-pip debs=python3 python3-dev python3-pip
@ -124,8 +127,12 @@ package :
run : run :
(cd $(lw_source_dir) && ./mach run) (cd $(lw_source_dir) && ./mach run)
check-patchfail: check-patchfail:
sh -c "./scripts/check-patchfail.sh" > patchfail.out sh -c "./scripts/check-patchfail.sh" > patchfail.out
check-fuzz: check-fuzz:
-sh -c "./scripts/check-patchfail.sh --fuzz=0" > patchfail-fuzz.out -sh -c "./scripts/check-patchfail.sh --fuzz=0" > patchfail-fuzz.out
fixfuzz : fixfuzz :
@ -158,3 +165,18 @@ setup-debian :
setup-fedora : setup-fedora :
dnf -y install python3 curl wget zstd python3-devel python3-pip mercurial openssl-devel libxml2-devel dnf -y install python3 curl wget zstd python3-devel python3-pip mercurial openssl-devel libxml2-devel
#
# for .woodpecker.yml
#
check-patchfail-woodpecker :
( sh -c "./scripts/check-patchfail.sh" > patchfail.out ; exit_code=$$? ; \
cat patchfail.out ; rm -f patchfail.out ; exit $$exit_code )
fetch-upstream-woodpecker : fetch

View file

@ -1 +1 @@
116.0.2 116.0.3