Warehouses #3

Merged
trent merged 38 commits from Warehouses into master 2026-01-10 21:16:09 +00:00
Showing only changes of commit a26a52b078 - Show all commits

View File

@@ -1,10 +1,16 @@
skip_clone: true skip_clone: true
when: wwhen:
event: [push, tag, manual] event: push
branch: [master] branch: master
steps: steps:
debug-location:
image: alpine
commands:
- pwd # gdzie aktualnie jesteśmy
- ls -la # co jest w bieżącym katalogu
- find /woodpecker -maxdepth 4 -type d 2>/dev/null
clone-manual: clone-manual:
image: woodpeckerci/plugin-git image: woodpeckerci/plugin-git
settings: settings:
@@ -17,8 +23,8 @@ steps:
commands: commands:
- | - |
set -euf set -euf
CODE_DIR="/woodpecker/src/localhost/git/FA/FA_WEB" cd "${CI_WORKSPACE}"
cd "$CODE_DIR" echo "Aktualna ścieżka: $(pwd)"
echo "=== Restore wszystkich projektów ===" echo "=== Restore wszystkich projektów ==="
find . -name "*.csproj" -type f -exec dotnet restore "{}" \; find . -name "*.csproj" -type f -exec dotnet restore "{}" \;
@@ -27,8 +33,7 @@ steps:
commands: commands:
- | - |
set -euf set -euf
CODE_DIR="/woodpecker/src/localhost/git/FA/FA_WEB" cd "${CI_WORKSPACE}"
cd "$CODE_DIR"
echo "=== Uruchamianie testów ===" echo "=== Uruchamianie testów ==="
dotnet test --no-restore --configuration Release --logger "trx" dotnet test --no-restore --configuration Release --logger "trx"
depends_on: [restore] depends_on: [restore]
@@ -38,11 +43,9 @@ steps:
commands: commands:
- | - |
set -euf set -euf
cd "${CI_WORKSPACE}"
echo "=== Instalacja MinVer CLI ===" echo "=== Instalacja MinVer CLI ==="
dotnet tool install --tool-path /tmp/minver minver-cli dotnet tool install --tool-path /tmp/minver minver-cli
CODE_DIR="/woodpecker/src/localhost/git/FA/FA_WEB"
cd "$CODE_DIR"
echo "=== Obliczona wersja przez MinVer ===" echo "=== Obliczona wersja przez MinVer ==="
MINVER_VERSION=$(/tmp/minver/minver \ MINVER_VERSION=$(/tmp/minver/minver \
--auto-increment patch \ --auto-increment patch \
@@ -53,7 +56,6 @@ steps:
echo "Wersja: $MINVER_VERSION" echo "Wersja: $MINVER_VERSION"
mkdir -p nupkg mkdir -p nupkg
echo "=== Pełniejsze fetch git (unshallow + tags) ===" echo "=== Pełniejsze fetch git (unshallow + tags) ==="
git fetch --prune --unshallow || echo "Już full clone OK" git fetch --prune --unshallow || echo "Już full clone OK"
git fetch --tags git fetch --tags
@@ -63,7 +65,6 @@ steps:
git tag -l git tag -l
echo "=== Aktualny commit i opis ===" echo "=== Aktualny commit i opis ==="
git describe --tags --always --dirty git describe --tags --always --dirty
echo "=== Diagnostyka projektów ===" echo "=== Diagnostyka projektów ==="
find . -name "*.csproj" -type f | sort find . -name "*.csproj" -type f | sort
mkdir -p nupkg mkdir -p nupkg
@@ -72,7 +73,6 @@ steps:
if grep -q '<PackageId>' "$csproj"; then if grep -q '<PackageId>' "$csproj"; then
PROJECT_NAME=$(basename "$csproj" .csproj) PROJECT_NAME=$(basename "$csproj" .csproj)
echo "→ Pakuję $PROJECT_NAME ($csproj)" echo "→ Pakuję $PROJECT_NAME ($csproj)"
#dotnet pack "$csproj" --configuration Release -o "$CODE_DIR/nupkg" /p:PackageVersion=$MINVER_VERSION
dotnet pack "$csproj" \ dotnet pack "$csproj" \
--configuration Release \ --configuration Release \
-o "./nupkg" \ -o "./nupkg" \
@@ -94,12 +94,9 @@ steps:
commands: commands:
- | - |
set -euf set -euf
CODE_DIR="/woodpecker/src/localhost/git/FA/FA_WEB" cd "${CI_WORKSPACE}"
cd "$CODE_DIR"
echo "=== Test połączenia z BaGetter ===" echo "=== Test połączenia z BaGetter ==="
curl -f http://baget:80/v3/index.json || echo "Nie można połączyć się z BaGetter!" curl -f http://baget:80/v3/index.json || echo "Nie można połączyć się z BaGetter!"
# Tworzymy minimalny NuGet.Config tylko po to, żeby odblokować HTTP dla nazwanego źródła # Tworzymy minimalny NuGet.Config tylko po to, żeby odblokować HTTP dla nazwanego źródła
cat <<EOF > NuGet.Config cat <<EOF > NuGet.Config
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
@@ -111,10 +108,8 @@ steps:
</packageSources> </packageSources>
</configuration> </configuration>
EOF EOF
echo "=== Użyty NuGet.Config (tylko do odblokowania HTTP) ===" echo "=== Użyty NuGet.Config (tylko do odblokowania HTTP) ==="
cat NuGet.Config cat NuGet.Config
echo "=== Publikacja pakietów do BaGetter ===" echo "=== Publikacja pakietów do BaGetter ==="
find ./nupkg -name "*.nupkg" -type f | while read pkg; do find ./nupkg -name "*.nupkg" -type f | while read pkg; do
echo "→ Push $(basename "$pkg")" echo "→ Push $(basename "$pkg")"
@@ -123,20 +118,15 @@ steps:
--api-key "$BAGETTER_API_KEY" \ --api-key "$BAGETTER_API_KEY" \
--skip-duplicate --skip-duplicate
done done
echo "Wszystkie pakiety DataModel opublikowane w BaGetter!" echo "Wszystkie pakiety DataModel opublikowane w BaGetter!"
depends_on: [pack-datamodels] depends_on: [pack-datamodels]
build-and-publish-apps: build-and-publish-apps:
image: mcr.microsoft.com/dotnet/sdk:latest image: mcr.microsoft.com/dotnet/sdk:latest
# environment:
# DEPLOY_SSH_KEY:
# from_secret: deploy_ssh_key
commands: commands:
- | - |
set -euf set -euf
CODE_DIR="/woodpecker/src/localhost/git/FA/FA_WEB" cd "${CI_WORKSPACE}"
cd "$CODE_DIR"
echo "=== Ponowny restore aplikacji (z najnowszymi pakietami z BaGetter) ===" echo "=== Ponowny restore aplikacji (z najnowszymi pakietami z BaGetter) ==="
find . -name "*.csproj" -type f -exec dotnet restore "{}" \; find . -name "*.csproj" -type f -exec dotnet restore "{}" \;
echo "=== Publish aplikacji ===" echo "=== Publish aplikacji ==="
@@ -150,7 +140,7 @@ steps:
continue continue
fi fi
echo "→ Publish $PROJECT_NAME ($csproj)" echo "→ Publish $PROJECT_NAME ($csproj)"
dotnet publish "$csproj" --no-restore -c Release -o "$CODE_DIR/publish-$PROJECT_NAME" dotnet publish "$csproj" --no-restore -c Release -o "./publish-$PROJECT_NAME"
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←← # ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
# Tu wstaw swój kod deployu (rsync/ssh itp.) # Tu wstaw swój kod deployu (rsync/ssh itp.)
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←← # ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←