Update .woodpecker.yml #23

Open
trent wants to merge 58 commits from Warehouses into master
Showing only changes of commit 81af6f02d9 - Show all commits

View File

@@ -11,12 +11,14 @@ 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:
@@ -26,6 +28,7 @@ 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:
@@ -35,6 +38,7 @@ 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:
@@ -78,6 +82,7 @@ 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:
@@ -108,6 +113,18 @@ steps:
--skip-duplicate --skip-duplicate
done done
depends_on: [pack-datamodels] depends_on: [pack-datamodels]
prepare-restore-for-docker:
image: mcr.microsoft.com/dotnet/sdk:latest
commands:
- |
set -euf
cd "${CI_WORKSPACE}"
echo "=== Przygotowanie do budowania obrazów ==="
dotnet restore
echo "Restore dla projektów zakończone"
depends_on: [publish-datamodels-to-baget]
containerize-apps: containerize-apps:
image: woodpeckerci/plugin-docker-buildx:latest image: woodpeckerci/plugin-docker-buildx:latest
environment: environment:
@@ -118,46 +135,64 @@ steps:
commands: commands:
- | - |
set -euf set -euf
cd "${CI_WORKSPACE}" cd "${CI_WORKSPACE}"
echo "DEBUG: Użytkownik = '$GITEA_USER'" echo "DEBUG: Użytkownik = '$GITEA_USER'"
echo "DEBUG: Token (pierwsze 4 znaki) = $GITEA_TOKEN..." 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 echo "$GITEA_TOKEN" | docker login git.modwad.pl -u "$GITEA_USER" --password-stdin || {
echo "Błąd logowania do rejestru"
exit 1
}
find . -name "*.csproj" -type f | while read csproj; do find . -name "*.csproj" -type f | while read csproj; do
PROJECT_DIR=$(dirname "$csproj") PROJECT_DIR=$(dirname "$csproj")
PROJECT_NAME=$(basename "$csproj" .csproj) PROJECT_NAME=$(basename "$csproj" .csproj)
PROJECT_TYPE=$(dotnet msbuild "$csproj" -getProperty:ProjectType -noLogo 2>/dev/null || echo "Unknown")
DEPLOY_TO_CENTRAL=$(dotnet msbuild "$csproj" -getProperty:DeployToCentral -noLogo 2>/dev/null || echo "false") # Tymczasowo pomijamy projekty, które nie mają iść do centralnego rejestru
if [ "$DEPLOY_TO_CENTRAL" != "true" ] || [[ "$PROJECT_TYPE" == "Unknown" || "$PROJECT_TYPE" == "DataModel" || "$PROJECT_TYPE" == "LinuxLocal" ]]; then # Jeśli masz dokładne kryterium → możesz dodać grep po <DeployToCentral>true</DeployToCentral>
echo "Pomijam $PROJECT_NAME ($PROJECT_TYPE)" # Na razie prosty filtr po nazwie (dostosuj do swoich konwencji)
continue case "$PROJECT_NAME" in
fi *DataModel*|*LinuxLocal*)
echo "Pomijam $PROJECT_NAME (DataModel / LinuxLocal)"
continue ;;
esac
IMAGE_NAME="trent/${PROJECT_NAME,,}" IMAGE_NAME="trent/${PROJECT_NAME,,}"
FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}" FULL_IMAGE="git.modwad.pl/${IMAGE_NAME}"
echo "Przygotowuję Dockerfile dla ${PROJECT_NAME}"
cat > "${PROJECT_DIR}/Dockerfile.temp" <<-EOF 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
WORKDIR /src FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build
COPY . . WORKDIR /src
RUN dotnet restore "${PROJECT_NAME}.csproj" COPY . .
RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false RUN dotnet restore "${PROJECT_NAME}.csproj"
FROM base AS final RUN dotnet publish "${PROJECT_NAME}.csproj" -c Release -o /app/publish /p:UseAppHost=false
WORKDIR /app
COPY --from=build /app/publish . FROM base AS final
ENV ASPNETCORE_URLS=http://+:8080 WORKDIR /app
ENTRYPOINT ["dotnet", "${PROJECT_NAME}.dll"] COPY --from=build /app/publish .
ENV ASPNETCORE_URLS=http://+:8080
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" \
--push \
"${PROJECT_DIR}" "${PROJECT_DIR}"
docker push "${FULL_IMAGE}:${CI_COMMIT_SHA}"
docker push "${FULL_IMAGE}:latest"
rm -f "${PROJECT_DIR}/Dockerfile.temp" rm -f "${PROJECT_DIR}/Dockerfile.temp"
echo "Opublikowano: ${FULL_IMAGE}:latest" echo "Opublikowano: ${FULL_IMAGE}:latest"
done done
depends_on: [publish-datamodels-to-baget] depends_on: [prepare-restore-for-docker]