Update .woodpecker.yml
This commit is contained in:
110
.woodpecker.yml
110
.woodpecker.yml
@@ -11,14 +11,12 @@ steps:
|
|||||||
- pwd
|
- pwd
|
||||||
- ls -la
|
- 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:
|
||||||
remote: http://gitea:3000/FA/FA_WEB.git
|
remote: http://gitea:3000/FA/FA_WEB.git
|
||||||
branch: master
|
branch: master
|
||||||
depth: 1
|
depth: 1
|
||||||
|
|
||||||
restore:
|
restore:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
@@ -28,7 +26,6 @@ steps:
|
|||||||
echo "Aktualna ścieżka: $(pwd)"
|
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 "{}" \;
|
||||||
|
|
||||||
test:
|
test:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
@@ -38,7 +35,6 @@ steps:
|
|||||||
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]
|
||||||
|
|
||||||
pack-datamodels:
|
pack-datamodels:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
commands:
|
commands:
|
||||||
@@ -53,14 +49,11 @@ 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
|
||||||
|
|
||||||
echo "=== Dostępne tagi ==="
|
echo "=== Dostępne tagi ==="
|
||||||
git tag -l
|
git tag -l
|
||||||
echo "=== Aktualny commit i opis ==="
|
echo "=== Aktualny commit i opis ==="
|
||||||
@@ -85,7 +78,6 @@ steps:
|
|||||||
echo "=== Spakowane pakiety ==="
|
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]
|
||||||
|
|
||||||
publish-datamodels-to-baget:
|
publish-datamodels-to-baget:
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
environment:
|
environment:
|
||||||
@@ -116,78 +108,66 @@ steps:
|
|||||||
--skip-duplicate
|
--skip-duplicate
|
||||||
done
|
done
|
||||||
depends_on: [pack-datamodels]
|
depends_on: [pack-datamodels]
|
||||||
|
containerize-apps:
|
||||||
|
image: mcr.microsoft.com/dotnet/sdk:latest
|
||||||
|
privileged: true
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
environment:
|
||||||
|
GITEA_USER:
|
||||||
|
from_secret: gitea_registry_user
|
||||||
|
GITEA_TOKEN:
|
||||||
|
from_secret: gitea_registry_token
|
||||||
|
commands:
|
||||||
|
- |
|
||||||
|
set -euf
|
||||||
|
cd "${CI_WORKSPACE}"
|
||||||
|
|
||||||
containerize-apps:
|
# Instalacja narzędzi Docker w kontenerze .NET (Alpine-based)
|
||||||
image: mcr.microsoft.com/dotnet/sdk:latest
|
apk update && apk add --no-cache docker docker-cli-buildx
|
||||||
volumes:
|
|
||||||
- /var/run/docker.sock:/var/run/docker.sock
|
|
||||||
environment:
|
|
||||||
GITEA_USER:
|
|
||||||
from_secret: gitea_registry_user
|
|
||||||
GITEA_TOKEN:
|
|
||||||
from_secret: gitea_registry_token
|
|
||||||
commands:
|
|
||||||
- |
|
|
||||||
set -euf
|
|
||||||
cd "${CI_WORKSPACE}"
|
|
||||||
|
|
||||||
# Instalacja Docker CLI i buildx (potrzebne w kontenerze .NET)
|
echo "DEBUG: Użytkownik = '$GITEA_USER'"
|
||||||
apk update && apk add --no-cache docker docker-cli-buildx
|
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN..."
|
||||||
# Uruchomienie dockerd jeśli potrzeba (nie zawsze wymagane przy sock)
|
|
||||||
# dockerd-entrypoint.sh & sleep 5 # opcjonalne, jeśli masz problemy z sock
|
|
||||||
|
|
||||||
echo "DEBUG: Użytkownik = '$GITEA_USER'"
|
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
||||||
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN:0:4..."
|
|
||||||
|
|
||||||
echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin
|
dotnet restore
|
||||||
|
|
||||||
dotnet restore
|
find . -name "*.csproj" -type f | while read csproj; do
|
||||||
|
PROJECT_DIR=$(dirname "$csproj")
|
||||||
find . -name "*.csproj" -type f | while read csproj; do
|
PROJECT_NAME=$(basename "$csproj" .csproj)
|
||||||
PROJECT_DIR=$(dirname "$csproj")
|
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
||||||
PROJECT_NAME=$(basename "$csproj" .csproj)
|
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false")
|
||||||
|
if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then
|
||||||
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
|
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)"
|
||||||
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
|
IMAGE_NAME="trent/${PROJECT_NAME,,}"
|
||||||
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)"
|
FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
|
||||||
continue
|
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
|
||||||
fi
|
|
||||||
|
|
||||||
IMAGE_NAME="trent/${PROJECT_NAME,,}"
|
|
||||||
FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
|
|
||||||
|
|
||||||
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF
|
|
||||||
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
EXPOSE 8080
|
EXPOSE 8080
|
||||||
|
|
||||||
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
|
||||||
WORKDIR /src
|
WORKDIR /src
|
||||||
COPY . .
|
COPY . .
|
||||||
RUN dotnet restore "${PROJECT_NAME}.csproj"
|
RUN dotnet restore "${PROJECT_NAME}.csproj"
|
||||||
RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
|
RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
|
||||||
|
|
||||||
FROM base AS final
|
FROM base AS final
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY --from=build /app/publish .
|
COPY --from=build /app/publish .
|
||||||
ENV ASPNETCORE_URLS=http://+:8080
|
ENV ASPNETCORE_URLS=http://+:8080
|
||||||
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"]
|
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"]
|
||||||
EOF
|
EOF
|
||||||
|
echo "Buduję → ${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
||||||
echo "Buduję → ${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
docker buildx build --platform linux/amd64 \
|
||||||
docker buildx build --platform linux/amd64 \
|
-t "${FULL_IMAGE}:${CI_COMMIT_SHA}" \
|
||||||
-t "${FULL_IMAGE}:${CI_COMMIT_SHA}" \
|
-t "${FULL_IMAGE}:latest" \
|
||||||
-t "${FULL_IMAGE}:latest" \
|
-f "${PROJECT_DIR}/Dockerfile.temp" \
|
||||||
-f "${PROJECT_DIR}/Dockerfile.temp" \
|
"${PROJECT_DIR}"
|
||||||
"${PROJECT_DIR}"
|
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
||||||
|
docker push "${FULL_IMAGE}:latest"
|
||||||
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
|
rm -f "${PROJECT_DIR}/Dockerfile.temp"
|
||||||
docker push "${FULL_IMAGE}:latest"
|
echo "Opublikowano: ${FULL_IMAGE}:latest"
|
||||||
|
done
|
||||||
rm -f "${PROJECT_DIR}/Dockerfile.temp"
|
depends_on: [publish-datamodels-to-baget]
|
||||||
|
|
||||||
echo "Opublikowano: ${FULL_IMAGE}:latest"
|
|
||||||
done
|
|
||||||
depends_on: [publish-datamodels-to-baget]
|
|
||||||
Reference in New Issue
Block a user