force pipeline detection - dodanie cache buster w .woodpecker.yml #2
@@ -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,32 +43,28 @@ 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 \
|
||||||
--minimum-major-minor 2.0 \
|
--minimum-major-minor 2.0 \
|
||||||
--default-pre-release-identifiers alpha.0 \
|
--default-pre-release-identifiers alpha.0 \
|
||||||
--verbosity info)
|
--verbosity info)
|
||||||
|
|
||||||
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
|
||||||
|
|
||||||
# Diagnostyka – sprawdź czy tag jest widoczny
|
# Diagnostyka – sprawdź czy tag jest widoczny
|
||||||
echo "=== Dostępne tagi ==="
|
echo "=== Dostępne tagi ==="
|
||||||
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,11 +73,10 @@ 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" \
|
||||||
/p:PackageVersion=$MINVER_VERSION
|
/p:PackageVersion=$MINVER_VERSION
|
||||||
else
|
else
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
echo "→ Pomijam $PROJECT_NAME – brak <PackageId> (nie jest to biblioteka NuGet)"
|
echo "→ Pomijam $PROJECT_NAME – brak <PackageId> (nie jest to biblioteka NuGet)"
|
||||||
@@ -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.)
|
||||||
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
||||||
@@ -159,4 +149,4 @@ steps:
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo "Pipeline zakończony pomyślnie!"
|
echo "Pipeline zakończony pomyślnie!"
|
||||||
depends_on: [publish-datamodels-to-baget]
|
depends_on: [publish-datamodels-to-baget]
|
||||||
|
|||||||
Reference in New Issue
Block a user