Merge pull request 'Update .woodpecker.yml' (#12) from Warehouses into master
Reviewed-on: #12
This commit was merged in pull request #12.
This commit is contained in:
103
.woodpecker.yml
103
.woodpecker.yml
@@ -1,18 +1,17 @@
|
|||||||
skip_clone: true
|
skip_clone: true
|
||||||
|
|
||||||
when:
|
when:
|
||||||
event: pull_request
|
event: pull_request
|
||||||
action:
|
action:
|
||||||
- merge
|
- merge
|
||||||
branch: master
|
branch: master
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
debug-location:
|
debug-location:
|
||||||
image: alpine
|
image: alpine
|
||||||
commands:
|
commands:
|
||||||
- pwd # gdzie aktualnie jesteśmy
|
- pwd
|
||||||
- ls -la # co jest w bieżącym katalogu
|
- ls -la
|
||||||
- find /woodpecker -maxdepth 4 -type d 2>/dev/null
|
- find /woodpecker -maxdepth 4 -type d 2>/dev/null
|
||||||
|
|
||||||
clone-manual:
|
clone-manual:
|
||||||
image: woodpeckerci/plugin-git
|
image: woodpeckerci/plugin-git
|
||||||
settings:
|
settings:
|
||||||
@@ -54,15 +53,14 @@ steps:
|
|||||||
--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
|
|
||||||
echo "=== Dostępne tagi ==="
|
echo "=== Dostępne tagi ==="
|
||||||
git tag -l
|
git tag -l
|
||||||
echo "=== Aktualny commit i opis ==="
|
echo "=== Aktualny commit i opis ==="
|
||||||
@@ -81,10 +79,10 @@ steps:
|
|||||||
/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>"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo "=== Spakowane pakiety (.nupkg) ==="
|
echo "=== Spakowane pakiety ==="
|
||||||
ls -la nupkg/ || echo "Brak spakowanych pakietów!"
|
ls -la nupkg/ || echo "Brak spakowanych pakietów!"
|
||||||
depends_on: [test]
|
depends_on: [test]
|
||||||
|
|
||||||
@@ -99,7 +97,6 @@ steps:
|
|||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
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
|
|
||||||
cat <<EOF > NuGet.Config
|
cat <<EOF > NuGet.Config
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<configuration>
|
<configuration>
|
||||||
@@ -110,8 +107,6 @@ steps:
|
|||||||
</packageSources>
|
</packageSources>
|
||||||
</configuration>
|
</configuration>
|
||||||
EOF
|
EOF
|
||||||
echo "=== Użyty NuGet.Config (tylko do odblokowania HTTP) ==="
|
|
||||||
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")"
|
||||||
@@ -120,35 +115,73 @@ steps:
|
|||||||
--api-key "$BAGETTER_API_KEY" \
|
--api-key "$BAGETTER_API_KEY" \
|
||||||
--skip-duplicate
|
--skip-duplicate
|
||||||
done
|
done
|
||||||
echo "Wszystkie pakiety DataModel opublikowane w BaGetter!"
|
|
||||||
depends_on: [pack-datamodels]
|
depends_on: [pack-datamodels]
|
||||||
|
|
||||||
build-and-publish-apps:
|
containerize-apps:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: woodpeckerci/plugin-docker-buildx:latest
|
||||||
|
settings:
|
||||||
|
registry: git.modwad.pl
|
||||||
|
username:
|
||||||
|
from_secret: gitea_registry_user
|
||||||
|
password:
|
||||||
|
from_secret: gitea_registry_token
|
||||||
commands:
|
commands:
|
||||||
- |
|
- |
|
||||||
set -euf
|
set -euf
|
||||||
cd "${CI_WORKSPACE}"
|
cd "${CI_WORKSPACE}"
|
||||||
echo "=== Ponowny restore aplikacji (z najnowszymi pakietami z BaGetter) ==="
|
|
||||||
find . -name "*.csproj" -type f -exec dotnet restore "{}" \;
|
# Logowanie do rejestru
|
||||||
echo "=== Publish aplikacji ==="
|
echo "${PLUGIN_PASSWORD}" | docker login "${PLUGIN_REGISTRY}" -u "${PLUGIN_USERNAME}" --password-stdin
|
||||||
|
|
||||||
|
# Restore raz jeszcze – bo w tym kroku nie mamy zależności od wcześniejszego restore
|
||||||
|
dotnet restore
|
||||||
|
|
||||||
find . -name "*.csproj" -type f | while read csproj; do
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
|
||||||
PROJECT_DIR=$(dirname "$csproj")
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
if [[ "$PROJECT_NAME" == *"Api"* ]] || [[ "$PROJECT_NAME" == *"Blazor"* ]] || [[ "$PROJECT_DIR" == *"/Api/"* ]] || [[ "$PROJECT_DIR" == *"/Blazor/"* ]]; then
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
|
||||||
if [ "$DEPLOY_TO_CENTRAL" != "true" ]; then
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
echo "Pomijam $PROJECT_NAME (DeployToCentral ≠ true)"
|
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
||||||
continue
|
|
||||||
fi
|
if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
|
||||||
echo "→ Publish $PROJECT_NAME ($csproj)"
|
echo "Pomijam konteneryzację $PROJECT_NAME ($PROJECT_TYPE)"
|
||||||
dotnet publish "$csproj" --no-restore -c Release -o "./publish-$PROJECT_NAME"
|
continue
|
||||||
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
|
||||||
# Tu wstaw swój kod deployu (rsync/ssh itp.)
|
|
||||||
# ←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←←
|
|
||||||
else
|
|
||||||
echo "Pomijam $PROJECT_NAME (nie jest to Api ani Blazor)"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
IMAGE_NAME="projekty/${PROJECT_NAME,,}" # np. projekty/customerapi
|
||||||
|
FULL_IMAGE="${PLUGIN_REGISTRY}/${IMAGE_NAME}"
|
||||||
|
|
||||||
|
# Generujemy tymczasowy Dockerfile
|
||||||
|
cat <<'EOF' > "${PROJECT_DIR}/Dockerfile.temp"
|
||||||
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
||||||
|
WORKDIR /app
|
||||||
|
EXPOSE 8080
|
||||||
|
|
||||||
|
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
||||||
|
WORKDIR /src
|
||||||
|
COPY . .
|
||||||
|
RUN dotnet restore "${PROJECT_NAME}.csproj"
|
||||||
|
RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
|
||||||
|
|
||||||
|
FROM base AS final
|
||||||
|
WORKDIR /app
|
||||||
|
COPY --from=build /app/publish .
|
||||||
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
|
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"]
|
||||||
|
EOF
|
||||||
|
|
||||||
|
echo "Buduję → ${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
||||||
|
docker buildx build --platform linux/amd64 \
|
||||||
|
-t "${FULL_IMAGE}:${CI_COMMIT_SHA}" \
|
||||||
|
-t "${FULL_IMAGE}:latest" \
|
||||||
|
-f "${PROJECT_DIR}/Dockerfile.temp" \
|
||||||
|
"${PROJECT_DIR}"
|
||||||
|
|
||||||
|
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
||||||
|
docker push "${FULL_IMAGE}:latest"
|
||||||
|
|
||||||
|
rm -f "${PROJECT_DIR}/Dockerfile.temp"
|
||||||
|
|
||||||
|
echo "Opublikowano: ${FULL_IMAGE}:latest"
|
||||||
done
|
done
|
||||||
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