build: add docker-compose & NUKE buildsystem
All checks were successful
Test if Server can be built / build-server (push) Successful in 24s

This commit is contained in:
Timothy Schenk 2023-10-09 15:29:53 +02:00
parent 68c1cae587
commit 2a1dec45d8
5 changed files with 95 additions and 7 deletions

View file

@ -6,6 +6,11 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Benchmarks", "Benchmarks\Be
EndProject EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "_build", "build\_build.csproj", "{046A3B46-FC08-4B08-A52A-1DC5D426120D}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "_build", "build\_build.csproj", "{046A3B46-FC08-4B08-A52A-1DC5D426120D}"
EndProject EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{C1303691-99F6-41CE-BAD3-2CA112D75DBF}"
ProjectSection(SolutionItems) = preProject
docker-compose.yml = docker-compose.yml
EndProjectSection
EndProject
Global Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU Debug|Any CPU = Debug|Any CPU

View file

@ -70,7 +70,7 @@
<ItemGroup> <ItemGroup>
<Content Include="settings.Development.json"> <Content Include="settings.Development.json">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>Always</CopyToOutputDirectory>
</Content> </Content>
</ItemGroup> </ItemGroup>
</Project> </Project>

30
Server/docker-compose.yml Normal file
View file

@ -0,0 +1,30 @@
services:
server:
image: continuity-server:latest
environment:
- ENVIRONMENT=Development
- Testing:CreateAccountOnLogin=true
- DB:Host=db
- DB:Port=5432
- DB:Username=continuity
- DB:Password=continuity
networks:
- continuity
ports:
- "10001:10001"
db:
image: postgres:16.0-alpine
environment:
- POSTGRES_USER=continuity
- POSTGRES_DB=continuity
- POSTGRES_PASSWORD=continuity
networks:
- continuity
volumes:
- db-data:/var/lib/postgresql/data
networks:
continuity:
volumes:
db-data:

View file

@ -1,10 +1,10 @@
{ {
"DB": { "DB": {
"Username": "continuitydevuser", "Username": "continuity",
"Host": "perf.rainote.dev", "Host": "localhost",
"Password": "7>CU`D2/LKw6hD/7", "Password": "continuity",
"Database": "continuity", "Database": "continuity",
"Port": "13543" "Port": "5432"
}, },
"Testing": { "Testing": {
"CreateAccountOnLogin": true "CreateAccountOnLogin": true

View file

@ -2,11 +2,18 @@ using System;
using System.Linq; using System.Linq;
using Nuke.Common; using Nuke.Common;
using Nuke.Common.CI; using Nuke.Common.CI;
using Nuke.Common.CI.GitHubActions;
using Nuke.Common.Execution; using Nuke.Common.Execution;
using Nuke.Common.Git;
using Nuke.Common.IO; using Nuke.Common.IO;
using Nuke.Common.ProjectModel; using Nuke.Common.ProjectModel;
using Nuke.Common.Tooling; using Nuke.Common.Tooling;
using Nuke.Common.Tools.CodeMetrics;
using Nuke.Common.Tools.Docker;
using Nuke.Common.Tools.DotNet;
using Nuke.Common.Tools.SonarScanner;
using Nuke.Common.Utilities.Collections; using Nuke.Common.Utilities.Collections;
using Serilog;
using static Nuke.Common.EnvironmentInfo; using static Nuke.Common.EnvironmentInfo;
using static Nuke.Common.IO.FileSystemTasks; using static Nuke.Common.IO.FileSystemTasks;
using static Nuke.Common.IO.PathConstruction; using static Nuke.Common.IO.PathConstruction;
@ -18,27 +25,73 @@ class Build : NukeBuild
/// - JetBrains Rider https://nuke.build/rider /// - JetBrains Rider https://nuke.build/rider
/// - Microsoft VisualStudio https://nuke.build/visualstudio /// - Microsoft VisualStudio https://nuke.build/visualstudio
/// - Microsoft VSCode https://nuke.build/vscode /// - Microsoft VSCode https://nuke.build/vscode
public static int Main() => Execute<Build>(x => x.Information, x => x.Deploy);
public static int Main () => Execute<Build>(x => x.Compile);
[Parameter("Configuration to build - Default is 'Debug' (local) or 'Release' (server)")] [Parameter("Configuration to build - Default is 'Debug' (local) or 'Release' (server)")]
readonly Configuration Configuration = IsLocalBuild ? Configuration.Debug : Configuration.Release; readonly Configuration Configuration = IsLocalBuild ? Configuration.Debug : Configuration.Release;
GitRepository GitRepository => GitRepository.FromLocalDirectory(RootDirectory);
Target Information => _ => _
.Before(Clean)
.Executes(() =>
{
Log.Information("Branch Name: {BranchName}", GitRepository.Branch);
Log.Information("Commit: {Commit}", GitRepository.Commit);
});
Target Clean => _ => _ Target Clean => _ => _
.Before(Restore) .Before(Restore)
.Executes(() => .Executes(() =>
{ {
DotNetTasks.DotNetClean();
}); });
Target Restore => _ => _ Target Restore => _ => _
.Executes(() => .Executes(() =>
{ {
DotNetTasks.DotNetRestore();
}); });
Target Compile => _ => _ Target Compile => _ => _
.DependsOn(Clean)
.DependsOn(Restore) .DependsOn(Restore)
.Executes(() => .Executes(() =>
{ {
DockerTasks.DockerStackRm(settings => settings.SetStacks("continuity"));
DotNetTasks.DotNetBuild(settings => settings.SetNoRestore(true));
}); });
Target Pack => _ => _
.DependsOn(Compile)
.Executes(() =>
{
DockerTasks.DockerBuild(settings => settings
.SetPath(AbsolutePath.Create(RootDirectory))
.SetFile("Server/Dockerfile")
.SetTag("continuity-server:latest")
.SetCompress(true)
.SetProgress(ProgressType.auto));
if (!IsLocalBuild)
{
DockerTasks.DockerPush(settings => settings.SetName("continuity-server:latest"));
}
});
Target Deploy => _ => _.DependsOn(Pack).Executes(() =>
{
DockerTasks.DockerPull(settings => settings.SetName("postgres:16.0-alpine"));
if (IsLocalBuild)
{
var dockerComposeFile = AbsolutePath.Create(RootDirectory / "Server" / "docker-compose.yml");
DockerTasks.DockerStackDeploy(settings => settings
.AddComposeFile(dockerComposeFile)
.SetStack("continuity")
.SetPrune(true)
);
return;
}
Log.Error("Deploy is only available on local builds.");
});
} }