Skip to content

Commit f336f9c

Browse files
Merge branch 'trunk' into trunk
2 parents ac635bc + fbe116c commit f336f9c

File tree

3 files changed

+49
-8
lines changed

3 files changed

+49
-8
lines changed

dotnet/src/webdriver/Command.cs

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,7 @@
2121
using System.Collections.Generic;
2222
using System.Text.Json;
2323
using System.Text.Json.Serialization;
24+
using System.Text.Json.Serialization.Metadata;
2425

2526
namespace OpenQA.Selenium
2627
{
@@ -35,7 +36,7 @@ public class Command
3536

3637
private readonly static JsonSerializerOptions s_jsonSerializerOptions = new()
3738
{
38-
TypeInfoResolver = CommandJsonSerializerContext.Default,
39+
TypeInfoResolver = JsonTypeInfoResolver.Combine(CommandJsonSerializerContext.Default, new DefaultJsonTypeInfoResolver()),
3940
Converters = { new ResponseValueJsonConverter() }
4041
};
4142

dotnet/src/webdriver/SeleniumManager.cs

Lines changed: 6 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -40,8 +40,6 @@ public static class SeleniumManager
4040
{
4141
private static readonly ILogger _logger = Log.GetLogger(typeof(SeleniumManager));
4242

43-
private static readonly JsonSerializerOptions _serializerOptions = new() { PropertyNameCaseInsensitive = true, TypeInfoResolver = SeleniumManagerSerializerContext.Default };
44-
4543
private static readonly Lazy<string> _lazyBinaryFullPath = new(() =>
4644
{
4745
string? binaryFullPath = Environment.GetEnvironmentVariable("SE_MANAGER_PATH");
@@ -187,7 +185,7 @@ private static ResultResponse RunCommand(string fileName, string arguments)
187185

188186
try
189187
{
190-
jsonResponse = JsonSerializer.Deserialize<SeleniumManagerResponse>(output, _serializerOptions)!;
188+
jsonResponse = JsonSerializer.Deserialize(output, SeleniumManagerSerializerContext.Default.SeleniumManagerResponse)!;
191189
}
192190
catch (Exception ex)
193191
{
@@ -210,11 +208,11 @@ private static ResultResponse RunCommand(string fileName, string arguments)
210208
}
211209
}
212210

213-
internal record SeleniumManagerResponse(IReadOnlyList<LogEntryResponse> Logs, ResultResponse Result)
211+
internal sealed record SeleniumManagerResponse(IReadOnlyList<LogEntryResponse> Logs, ResultResponse Result)
214212
{
215-
public record LogEntryResponse(string Level, string Message);
213+
public sealed record LogEntryResponse(string Level, string Message);
216214

217-
public record ResultResponse
215+
public sealed record ResultResponse
218216
(
219217
[property: JsonPropertyName("driver_path")]
220218
string DriverPath,
@@ -224,5 +222,6 @@ string BrowserPath
224222
}
225223

226224
[JsonSerializable(typeof(SeleniumManagerResponse))]
227-
internal partial class SeleniumManagerSerializerContext : JsonSerializerContext;
225+
[JsonSourceGenerationOptions(PropertyNameCaseInsensitive = true)]
226+
internal sealed partial class SeleniumManagerSerializerContext : JsonSerializerContext;
228227
}

dotnet/test/common/CommandTests.cs

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
// <copyright file="CommandTests.cs" company="Selenium Committers">
2+
// Licensed to the Software Freedom Conservancy (SFC) under one
3+
// or more contributor license agreements. See the NOTICE file
4+
// distributed with this work for additional information
5+
// regarding copyright ownership. The SFC licenses this file
6+
// to you under the Apache License, Version 2.0 (the
7+
// "License"); you may not use this file except in compliance
8+
// with the License. You may obtain a copy of the License at
9+
//
10+
// http://www.apache.org/licenses/LICENSE-2.0
11+
//
12+
// Unless required by applicable law or agreed to in writing,
13+
// software distributed under the License is distributed on an
14+
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15+
// KIND, either express or implied. See the License for the
16+
// specific language governing permissions and limitations
17+
// under the License.
18+
// </copyright>
19+
20+
using NUnit.Framework;
21+
using System.Collections.Generic;
22+
23+
namespace OpenQA.Selenium
24+
{
25+
[TestFixture]
26+
public class CommandTests
27+
{
28+
[Test]
29+
public void CommandSerializesAnonymousType()
30+
{
31+
var parameters = new Dictionary<string, object>
32+
{
33+
["arg"] = new { param1 = true, param2 = false },
34+
};
35+
36+
var command = new Command(new SessionId("session"), "test command", parameters);
37+
38+
Assert.That(command.ParametersAsJsonString, Is.EqualTo("""{"arg":{"param1":true,"param2":false}}"""));
39+
}
40+
}
41+
}

0 commit comments

Comments
 (0)