Skip to content

Commit b919584

Browse files
authored
Merge branch 'trunk' into rb-bidi-network-module
2 parents 23e10f2 + a14b659 commit b919584

File tree

42 files changed

+383
-191
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

42 files changed

+383
-191
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+
}

java/src/org/openqa/selenium/netty/server/NettyServer.java

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,7 @@
2727
import io.netty.handler.ssl.SslContext;
2828
import io.netty.handler.ssl.SslContextBuilder;
2929
import io.netty.handler.ssl.util.SelfSignedCertificate;
30+
import io.netty.util.concurrent.Future;
3031
import io.netty.util.internal.logging.InternalLoggerFactory;
3132
import io.netty.util.internal.logging.JdkLoggerFactory;
3233
import java.io.IOException;
@@ -127,8 +128,11 @@ public URL getUrl() {
127128
@Override
128129
public void stop() {
129130
try {
130-
bossGroup.shutdownGracefully().sync();
131-
workerGroup.shutdownGracefully().sync();
131+
Future<?> bossShutdown = bossGroup.shutdownGracefully();
132+
Future<?> workerShutdown = workerGroup.shutdownGracefully();
133+
134+
bossShutdown.sync();
135+
workerShutdown.sync();
132136

133137
channel.closeFuture().sync();
134138
} catch (InterruptedException e) {

java/src/org/openqa/selenium/remote/http/HttpMessage.java

Lines changed: 5 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -29,11 +29,9 @@
2929
import java.util.HashMap;
3030
import java.util.List;
3131
import java.util.Map;
32-
import java.util.Objects;
3332
import java.util.Set;
3433
import java.util.function.BiConsumer;
3534
import java.util.function.Supplier;
36-
import java.util.stream.Collectors;
3735
import org.openqa.selenium.internal.Require;
3836

3937
abstract class HttpMessage<M extends HttpMessage<M>> {
@@ -92,11 +90,8 @@ public Iterable<String> getHeaderNames() {
9290
* @return an iterable view of the values
9391
*/
9492
public Iterable<String> getHeaders(String name) {
95-
return headers.entrySet().stream()
96-
.filter(e -> Objects.nonNull(e.getKey()))
97-
.filter(e -> e.getKey().equalsIgnoreCase(name.toLowerCase()))
98-
.flatMap((e) -> e.getValue().stream())
99-
.collect(Collectors.toList());
93+
return Collections.unmodifiableCollection(
94+
headers.getOrDefault(name.toLowerCase(), Collections.emptyList()));
10095
}
10196

10297
/**
@@ -106,12 +101,8 @@ public Iterable<String> getHeaders(String name) {
106101
* @return the value
107102
*/
108103
public String getHeader(String name) {
109-
return headers.entrySet().stream()
110-
.filter(e -> Objects.nonNull(e.getKey()))
111-
.filter(e -> e.getKey().equalsIgnoreCase(name.toLowerCase()))
112-
.flatMap((e) -> e.getValue().stream())
113-
.findFirst()
114-
.orElse(null);
104+
List<String> values = headers.getOrDefault(name.toLowerCase(), Collections.emptyList());
105+
return !values.isEmpty() ? values.get(0) : null;
115106
}
116107

117108
/**
@@ -146,7 +137,7 @@ public M addHeader(String name, String value) {
146137
* @return self
147138
*/
148139
public M removeHeader(String name) {
149-
headers.keySet().removeIf(header -> header.equalsIgnoreCase(name));
140+
headers.remove(name.toLowerCase());
150141
return self();
151142
}
152143

javascript/grid-ui/package.json

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@
44
"private": true,
55
"type": "module",
66
"dependencies": {
7-
"@apollo/client": "3.11.8",
7+
"@apollo/client": "3.11.9",
88
"@emotion/react": "11.13.3",
99
"@emotion/styled": "11.13.0",
1010
"@mui/icons-material": "5.15.18",
@@ -16,10 +16,10 @@
1616
"@types/react-dom": "18.2.22",
1717
"@types/react-modal": "3.16.3",
1818
"@types/react-router-dom": "5.3.3",
19-
"graphql": "16.8.1",
19+
"graphql": "16.9.0",
2020
"graphql.macro": "1.4.2",
2121
"path-browserify": "1.0.1",
22-
"pretty-ms": "9.0.0",
22+
"pretty-ms": "9.1.0",
2323
"react": "18.3.1",
2424
"react-dom": "18.3.1",
2525
"react-modal": "3.16.1",

javascript/node/selenium-webdriver/bidi/browsingContext.js

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -156,8 +156,7 @@ class BrowsingContext {
156156
method: 'browsingContext.create',
157157
params: Object.fromEntries(parameters),
158158
}
159-
const res = await this.bidi.send(params)
160-
return res
159+
return await this.bidi.send(params)
161160
}
162161

163162
/**

javascript/node/selenium-webdriver/bidi/continueRequestParameters.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ class ContinueRequestParameters {
4747
* Sets the cookies for the request.
4848
*
4949
* @param {Header[]} cookieHeaders - An array of cookie headers.
50-
* @returns {continueRequestParameters} - The current instance of the ContinueRequestParameters for chaining.
50+
* @returns {ContinueRequestParameters} - The current instance of the ContinueRequestParameters for chaining.
5151
* @throws {Error} - If a cookie header is not an instance of Header.
5252
*/
5353
cookies(cookieHeaders) {

javascript/node/selenium-webdriver/bidi/filterBy.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@ class FilterBy {
2121
}
2222

2323
static logLevel(level) {
24-
if (level === undefined || (level != undefined && !['debug', 'error', 'info', 'warning'].includes(level))) {
24+
if (level === undefined || (level !== undefined && !['debug', 'error', 'info', 'warning'].includes(level))) {
2525
throw Error(
2626
`Please pass valid log level. Valid log levels are 'debug', 'error', 'info' and 'warning'. Received: ${level}`,
2727
)

javascript/node/selenium-webdriver/bidi/logEntries.js

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,12 +21,13 @@ const { Source } = require('./scriptTypes')
2121

2222
/**
2323
* Represents a base log entry.
24-
* Desribed in https://w3c.github.io/webdriver-bidi/#types-log-logentry.
24+
* Described in https://w3c.github.io/webdriver-bidi/#types-log-logentry.
2525
*/
2626
class BaseLogEntry {
2727
/**
2828
* Creates a new instance of BaseLogEntry.
2929
* @param {string} level - The log level.
30+
* @param {source} source - Script Source
3031
* @param {string} text - The log source.
3132
* @param {string} text - The log text.
3233
* @param {number} timeStamp - The log timestamp.
@@ -86,6 +87,7 @@ class GenericLogEntry extends BaseLogEntry {
8687
/**
8788
* Creates an instance of GenericLogEntry.
8889
* @param {string} level - The log level.
90+
* @param {source} source - Script Source
8991
* @param {string} text - The log text.
9092
* @param {Date} timeStamp - The log timestamp.
9193
* @param {string} type - The log type.

0 commit comments

Comments
 (0)