Skip to content

Commit

Permalink
This commit adds deployment version to the build
Browse files Browse the repository at this point in the history
It also adds statistics about the build represented as execution data
  • Loading branch information
mudiagaobrikisil authored and johnml1135 committed Jan 2, 2025
1 parent 0cfd145 commit 94382ff
Show file tree
Hide file tree
Showing 22 changed files with 186 additions and 13 deletions.
2 changes: 1 addition & 1 deletion samples/ApiExample/ApiExample.csproj
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<Project Sdk="Microsoft.NET.Sdk">
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<OutputType>Exe</OutputType>
Expand Down
18 changes: 17 additions & 1 deletion src/DataAccess/src/SIL.DataAccess/MemoryUpdateBuilder.cs
Original file line number Diff line number Diff line change
Expand Up @@ -204,7 +204,23 @@ TField value
(IEnumerable<object> owners, PropertyInfo? prop, object? index) = GetFieldOwners(entity, filter, field);
object[]? indices = index == null ? null : [index];
foreach (object owner in owners)
prop.SetValue(owner, value, indices);
{
if (owner is IDictionary dictionary)
{
if (index != null)
{
dictionary[index] = value;
}
else
{
throw new ArgumentException("Cannot set a field on a dictionary without an index.", nameof(field));
}
}
else
{
prop.SetValue(owner, value, indices);
}
}
}

private static bool IsAnyMethod(MethodInfo mi)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using Polly.Extensions.Http;
using Polly.Extensions.Http;
using Serval.Translation.V1;

namespace Microsoft.Extensions.DependencyInjection;
Expand Down
3 changes: 2 additions & 1 deletion src/Machine/src/Serval.Machine.Shared/Models/Build.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace Serval.Machine.Shared.Models;
namespace Serval.Machine.Shared.Models;

public enum BuildJobState
{
Expand Down Expand Up @@ -29,4 +29,5 @@ public record Build
public required BuildJobRunnerType BuildJobRunner { get; init; }
public required BuildStage Stage { get; init; }
public string? Options { get; set; }
public IReadOnlyDictionary<string, string> ExecutionData { get; init; } = new Dictionary<string, string>();
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<Project Sdk="Microsoft.NET.Sdk">
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,4 +27,11 @@ Task InsertPretranslationsAsync(
Stream pretranslationsStream,
CancellationToken cancellationToken = default
);

Task UpdateBuildExecutionDataAsync(
string engineId,
string buildId,
IReadOnlyDictionary<string, string> executionData,
CancellationToken cancellationToken = default
);
}
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,13 @@ CancellationToken cancellationToken
);
}

var executionData = new Dictionary<string, string>()
{
{ "trainCount", trainCount.ToString(CultureInfo.InvariantCulture) },
{ "pretranslateCount", pretranslateCount.ToString(CultureInfo.InvariantCulture) }
};
await PlatformService.UpdateBuildExecutionDataAsync(engineId, buildId, executionData, cancellationToken);

cancellationToken.ThrowIfCancellationRequested();

bool canceling = !await BuildJobService.StartBuildJobAsync(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,5 @@ public static class ServalPlatformOutboxConstants
public const string BuildRestarting = "BuildRestarting";
public const string InsertPretranslations = "InsertPretranslations";
public const string IncrementTranslationEngineCorpusSize = "IncrementTranslationEngineCorpusSize";
public const string UpdateBuildExecutionData = "UpdateBuildExecutionData";
}
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,12 @@ await _client.IncrementTranslationEngineCorpusSizeAsync(
cancellationToken: cancellationToken
);
break;
case ServalPlatformOutboxConstants.UpdateBuildExecutionData:
await _client.UpdateBuildExecutionDataAsync(
JsonSerializer.Deserialize<UpdateBuildExecutionDataRequest>(content!),
cancellationToken: cancellationToken
);
break;
default:
throw new InvalidOperationException($"Encountered a message with the unrecognized method '{method}'.");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,4 +137,22 @@ await _outboxService.EnqueueMessageAsync(
cancellationToken: cancellationToken
);
}

public async Task UpdateBuildExecutionDataAsync(
string engineId,
string buildId,
IReadOnlyDictionary<string, string> executionData,
CancellationToken cancellationToken = default
)
{
var request = new UpdateBuildExecutionDataRequest { EngineId = engineId, BuildId = buildId };
request.ExecutionData.Add((IDictionary<string, string>)executionData);
await _outboxService.EnqueueMessageAsync(
ServalPlatformOutboxConstants.OutboxId,
ServalPlatformOutboxConstants.UpdateBuildExecutionData,
engineId,
JsonSerializer.Serialize(request),
cancellationToken: cancellationToken
);
}
}
3 changes: 3 additions & 0 deletions src/Serval/src/Serval.Client/Client.g.cs
Original file line number Diff line number Diff line change
Expand Up @@ -7644,6 +7644,9 @@ public partial class TranslationBuild
[Newtonsoft.Json.JsonProperty("deploymentVersion", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
public string? DeploymentVersion { get; set; } = default!;

[Newtonsoft.Json.JsonProperty("executionData", Required = Newtonsoft.Json.Required.Default, NullValueHandling = Newtonsoft.Json.NullValueHandling.Ignore)]
public System.Collections.Generic.IDictionary<string, string>? ExecutionData { get; set; } = default!;

}

[System.CodeDom.Compiler.GeneratedCode("NJsonSchema", "14.1.0.0 (NJsonSchema v11.0.2.0 (Newtonsoft.Json v13.0.0.0))")]
Expand Down
2 changes: 1 addition & 1 deletion src/Serval/src/Serval.Client/Serval.Client.csproj
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<Project Sdk="Microsoft.NET.Sdk">
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>netstandard2.1</TargetFramework>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ service TranslationPlatformApi {

rpc IncrementTranslationEngineCorpusSize(IncrementTranslationEngineCorpusSizeRequest) returns (google.protobuf.Empty);
rpc InsertPretranslations(stream InsertPretranslationsRequest) returns (google.protobuf.Empty);
rpc UpdateBuildExecutionData(UpdateBuildExecutionDataRequest) returns (google.protobuf.Empty);
}

message UpdateBuildStatusRequest {
Expand Down Expand Up @@ -59,3 +60,9 @@ message InsertPretranslationsRequest {
repeated string refs = 4;
string translation = 5;
}

message UpdateBuildExecutionDataRequest {
string engine_id = 1;
string build_id = 2;
map<string, string> execution_data = 3;
}
2 changes: 1 addition & 1 deletion src/Serval/src/Serval.Shared/Serval.Shared.csproj
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<Project Sdk="Microsoft.NET.Sdk">
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,11 @@ await c.Indexes.CreateOrUpdateAsync(
await c.Indexes.CreateOrUpdateAsync(
new CreateIndexModel<Build>(Builders<Build>.IndexKeys.Ascending(b => b.DateCreated))
);
// migrate by adding ExecutionData field
await c.UpdateManyAsync(
Builders<Build>.Filter.Exists(b => b.ExecutionData, false),
Builders<Build>.Update.Set(b => b.ExecutionData, new Dictionary<string, string>())
);
}
);
configurator.AddRepository<Pretranslation>(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace Serval.Translation.Contracts;
namespace Serval.Translation.Contracts;

public record TranslationBuildDto
{
Expand Down Expand Up @@ -28,4 +28,5 @@ public record TranslationBuildDto
/// </example>
public object? Options { get; init; }
public string? DeploymentVersion { get; init; }
public IReadOnlyDictionary<string, string>? ExecutionData { get; init; }
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace Serval.Translation.Controllers;
namespace Serval.Translation.Controllers;

#pragma warning disable CS0612 // Type or member is obsolete

Expand Down Expand Up @@ -1549,7 +1549,8 @@ private TranslationBuildDto Map(Build source)
State = source.State,
DateFinished = source.DateFinished,
Options = source.Options,
DeploymentVersion = source.DeploymentVersion
DeploymentVersion = source.DeploymentVersion,
ExecutionData = source.ExecutionData
};
}

Expand Down
3 changes: 2 additions & 1 deletion src/Serval/src/Serval.Translation/Models/Build.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
namespace Serval.Translation.Models;
namespace Serval.Translation.Models;

public record Build : IInitializableEntity
{
Expand All @@ -16,6 +16,7 @@ public record Build : IInitializableEntity
public DateTime? DateFinished { get; init; }
public IReadOnlyDictionary<string, object>? Options { get; init; }
public string? DeploymentVersion { get; init; }
public IReadOnlyDictionary<string, string> ExecutionData { get; init; } = new Dictionary<string, string>();
public bool? IsInitialized { get; set; }
public DateTime? DateCreated { get; set; }
}
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ await _publishEndpoint.Publish(
Owner = engine.Owner,
BuildState = build.State,
Message = build.Message!,
DateFinished = build.DateFinished!.Value
DateFinished = build.DateFinished!.Value,
},
ct
);
Expand Down Expand Up @@ -265,6 +265,25 @@ await _builds.UpdateAsync(
return Empty;
}

public override async Task<Empty> UpdateBuildExecutionData(
UpdateBuildExecutionDataRequest request,
ServerCallContext context
)
{
await _builds.UpdateAsync(
b => b.Id == request.BuildId,
u =>
{
// initialize ExecutionData if it's null
foreach (KeyValuePair<string, string> entry in request.ExecutionData)
u.Set(b => b.ExecutionData[entry.Key], entry.Value);
},
cancellationToken: context.CancellationToken
);

return new Empty();
}

public override async Task<Empty> IncrementTranslationEngineCorpusSize(
IncrementTranslationEngineCorpusSizeRequest request,
ServerCallContext context
Expand Down
2 changes: 1 addition & 1 deletion src/Serval/src/Serval.Webhooks/Serval.Webhooks.csproj
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<Project Sdk="Microsoft.NET.Sdk">
<Project Sdk="Microsoft.NET.Sdk">

<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
Expand Down
15 changes: 15 additions & 0 deletions src/Serval/test/Serval.E2ETests/ServalApiTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,21 @@ public async Task NmtBatch()
engineId,
cId2
);

TranslationBuild build = await _helperClient.TranslationEnginesClient.GetCurrentBuildAsync(engineId);
Assert.That(build.ExecutionData, Is.Not.Null);

var executionData = build.ExecutionData!;

Assert.That(executionData, Contains.Key("trainCount"));
Assert.That(executionData, Contains.Key("pretranslateCount"));

int trainCount = Convert.ToInt32(executionData["trainCount"], CultureInfo.InvariantCulture);
int pretranslateCount = Convert.ToInt32(executionData["pretranslateCount"], CultureInfo.InvariantCulture);

Assert.That(trainCount, Is.GreaterThan(0));
Assert.That(pretranslateCount, Is.GreaterThan(0));

Assert.That(lTrans2, Has.Count.EqualTo(13)); // just 2 John
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
using System.Globalization;
using Serval.Translation.V1;

namespace Serval.Translation.Services;
Expand Down Expand Up @@ -90,6 +91,70 @@ await env.PlatformService.UpdateBuildStatus(
Assert.That(env.Builds.Get("b0").PercentCompleted, Is.EqualTo(0.5));
}

[Test]
public async Task UpdateBuildExecutionData()
{
var env = new TestEnvironment();

var engine = new Engine()
{
Id = "e0",
Owner = "owner1",
Type = "nmt",
SourceLanguage = "en",
TargetLanguage = "es",
Corpora = []
};
await env.Engines.InsertAsync(engine);

var build = new Build()
{
Id = "123",
EngineRef = "e0",
ExecutionData = new Dictionary<string, string>
{
{ "trainCount", "0" },
{ "pretranslateCount", "0" },
{ "staticCount", "0" }
}
};
await env.Builds.InsertAsync(build);

Assert.That(build.ExecutionData, Is.Not.Null);

var executionData = build.ExecutionData;

Assert.That(executionData, Contains.Key("trainCount"));
Assert.That(executionData, Contains.Key("pretranslateCount"));

int trainCount = Convert.ToInt32(executionData["trainCount"], CultureInfo.InvariantCulture);
int pretranslateCount = Convert.ToInt32(executionData["pretranslateCount"], CultureInfo.InvariantCulture);
int staticCount = Convert.ToInt32(executionData["staticCount"], CultureInfo.InvariantCulture);

Assert.That(trainCount, Is.EqualTo(0));
Assert.That(pretranslateCount, Is.EqualTo(0));
Assert.That(staticCount, Is.EqualTo(0));

var updateRequest = new UpdateBuildExecutionDataRequest() { BuildId = "123", EngineId = engine.Id };
updateRequest.ExecutionData.Add(
new Dictionary<string, string> { { "trainCount", "4" }, { "pretranslateCount", "5" } }
);

await env.PlatformService.UpdateBuildExecutionData(updateRequest, env.ServerCallContext);

build = await env.Builds.GetAsync(c => c.Id == build.Id);

executionData = build!.ExecutionData;

trainCount = Convert.ToInt32(executionData["trainCount"], CultureInfo.InvariantCulture);
pretranslateCount = Convert.ToInt32(executionData["pretranslateCount"], CultureInfo.InvariantCulture);
staticCount = Convert.ToInt32(executionData["staticCount"], CultureInfo.InvariantCulture);

Assert.That(trainCount, Is.GreaterThan(0));
Assert.That(pretranslateCount, Is.GreaterThan(0));
Assert.That(staticCount, Is.EqualTo(0));
}

[Test]
public async Task IncrementCorpusSizeAsync()
{
Expand Down

0 comments on commit 94382ff

Please sign in to comment.