From a773b90cbf3eb7fecdd9ce2d187fba6fe7b94647 Mon Sep 17 00:00:00 2001 From: Viet Nguyen Duc Date: Mon, 23 Dec 2024 17:44:59 +0700 Subject: [PATCH 1/2] Update docs for Selenium Grid scaler Signed-off-by: Viet Nguyen Duc --- .../docs/2.16/scalers/selenium-grid-scaler.md | 220 +++++++++++++++--- .../docs/2.17/scalers/selenium-grid-scaler.md | 220 +++++++++++++++--- 2 files changed, 386 insertions(+), 54 deletions(-) diff --git a/content/docs/2.16/scalers/selenium-grid-scaler.md b/content/docs/2.16/scalers/selenium-grid-scaler.md index 6ce9d281a..4843d3d84 100644 --- a/content/docs/2.16/scalers/selenium-grid-scaler.md +++ b/content/docs/2.16/scalers/selenium-grid-scaler.md @@ -13,30 +13,31 @@ This specification describes the `selenium-grid` trigger that scales browser nod The scaler creates one browser node per pending request in session queue, divided by the max amount of sessions that can run in parallel. You will have to create one trigger per browser capability that you would like to support in your Selenium Grid. -The below is an example trigger configuration for chrome node. +The below is an example trigger configuration with default values represent. ```yaml triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' # Required. Can be ommitted if specified via TriggerAuthentication/ClusterTriggerAuthentication. - browserName: 'chrome' # Required - browserVersion: '91.0' # Optional. Only required when supporting multiple versions of browser in your Selenium Grid. - unsafeSsl : 'true' # Optional - activationThreshold: 5 # Optional - platformName: 'Linux' # Optional + browserName: '' # Optional. Required to be matched with the request in queue and Node stereotypes (Similarly for `browserVersion` and `platformName`). + browserVersion: '' # Optional. + platformName: 'linux' # Optional. + unsafeSsl : 'false' # Optional. + activationThreshold: 0 # Optional. ``` **Parameter list:** - `url` - Graphql url of your Selenium Grid. Refer to the Selenium Grid's documentation [here](https://www.selenium.dev/documentation/en/grid/grid_4/graphql_support/) to for more info. If endpoint requires authentication, you can use `TriggerAuthentication` to provide the credentials instead of embedding in the URL. -- `browserName` - Name of browser that usually gets passed in the browser capability. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. +- `browserName` - Name of browser that usually gets passed in the browser capability. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Optional) - `sessionBrowserName` - Name of the browser when it is an active session, only set if `BrowserName` changes between the queue and the active session. See the Edge example below for further detail. (Optional) - `browserVersion` - Version of browser that usually gets passed in the browser capability. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Optional) - `unsafeSsl` - Skip certificate validation when connecting over HTTPS. (Values: `true`, `false`, Default: `false`, Optional) - `activationThreshold` - Target value for activating the scaler. Learn more about activation [here](./../concepts/scaling-deployments.md#activating-and-scaling-thresholds). (Default: `0`, Optional) - `platformName` - Name of the browser platform. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Default: `Linux`, Optional) - `nodeMaxSessions` - Number of maximum sessions that can run in parallel on a Node. Update this parameter align with node config `--max-sessions` (`SE_NODE_MAX_SESSIONS`) to have the correct scaling behavior. (Default: `1`, Optional). +- `targetQueueLength` - The target number of queued sessions to scale on. (Default: `1`, Optional). **Trigger Authentication** - `username` - Username for basic authentication in GraphQL endpoint instead of embedding in the URL. (Optional) @@ -44,72 +45,233 @@ triggers: - `authType` - Type of authentication to be used. This can be set to `Bearer` or `OAuth2` in case Selenium Grid behind an Ingress proxy with other authentication types. (Optional) - `accessToken` - Access token. This is required when `authType` is set a value. (Optional) +### How does it work? + +The scaler will query the Hub GraphQL response to get the number of queued sessions in the specified combination of browser name, version, and platform. If the number of queued sessions is **equal to or greater than** the `targetQueueLength`, the scaler will scale up. + ### Example Here is a full example of scaled object definition using Selenium Grid trigger: ```yaml +kind: Deployment +metadata: + name: selenium-node-chrome + labels: + deploymentName: selenium-node-chrome +spec: + replicas: 1 + template: + spec: + containers: + - name: selenium-node-chrome + image: selenium/node-chrome:latest + ports: + - containerPort: 5555 + env: + - name: SE_NODE_BROWSER_VERSION + value: '' + +--- + apiVersion: keda.sh/v1alpha1 kind: ScaledObject metadata: - name: selenium-grid-chrome-scaledobject + name: selenium-grid-scaledobject-chrome + namespace: keda + labels: + deploymentName: selenium-node-chrome +spec: + maxReplicaCount: 8 + scaleTargetRef: + name: selenium-node-chrome + triggers: + - type: selenium-grid + metadata: + url: 'http://selenium-hub:4444/graphql' + browserName: 'chrome' + unsafeSsl : 'true' +``` + +Noted: +- From `v2.16.1+`, the trigger metadata `browserVersion`, `platformName` is recommended to be set explicitly to have the correct scaling behavior (especially when your Grid includes autoscaling Nodes, non-autoscaling Nodes, relay Nodes, etc.). Besides that, in client binding, it is also recommended to set the `browserVersion`, `platformName` to align with the trigger metadata. Please see below examples for more details. + +The above example will create Chrome browser nodes equal to the requests pending in session queue for Chrome browser, which is created from client. For example in Python binding + +```python +options = ChromeOptions() +options.set_capability('platformName', 'Linux') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) +``` + +With above script, the request is sent to Grid. Via GraphQL response, it looks like + +```json +{ + "data": { + "grid": { + "sessionCount": 0, + "maxSession": 0, + "totalSlots": 0 + }, + "nodesInfo": { + "nodes": [] + }, + "sessionsInfo": { + "sessionQueueRequests": [ + "{\"browserName\": \"chrome\", \"platformName\": \"linux\"}" + ] + } + } +} +``` + +In Node deployment spec, there is environment variable `SE_NODE_BROWSER_VERSION` which is set to empty. This is used to unset `browserVersion` in Node stereotypes (it is in project [docker-selenium](https://github.com/SeleniumHQ/docker-selenium) setting short browser build number by default), which is expected to match with the request capabilities in queue and scaler trigger metadata. + +When the request capabilities match with scaler trigger metadata, the scaler will create a new Node and connect to the Hub. Now the GraphQL response looks like + +```json +{ + "data": { + "grid": { + "sessionCount": 0, + "maxSession": 1, + "totalSlots": 1 + }, + "nodesInfo": { + "nodes": [ + { + "id": "UUID-of-Node", + "status": "UP", + "sessionCount": 0, + "maxSession": 1, + "slotCount": 1, + "stereotypes": "[{\"slots\": 1, \"stereotype\": {\"browserName\": \"chrome\", \"browserVersion\": \"\", \"platformName\": \"Linux\"}}]", + "sessions": [] + } + ] + }, + "sessionsInfo": { + "sessionQueueRequests": [ + "{\"browserName\": \"chrome\", \"platformName\": \"linux\"}" + ] + } + } +} +``` + +Now, the request can be picked up by the Node and the session is created. Session queue will be cleared and the scaler will not create a new Node until the next request comes in. + +Moreover, at the same time, you can create one more scaled object for Chrome browser request with specific `browserVersion`. For example + +```yaml +kind: Deployment +metadata: + name: selenium-node-chrome-131 + labels: + deploymentName: selenium-node-chrome-131 +spec: + replicas: 1 + template: + spec: + containers: + - name: selenium-node-chrome + image: selenium/node-chrome:131.0 + ports: + - containerPort: 5555 + +--- + +apiVersion: keda.sh/v1alpha1 +kind: ScaledObject +metadata: + name: selenium-grid-scaledobject-chrome-131 namespace: keda labels: - deploymentName: selenium-chrome-node + deploymentName: selenium-node-chrome-131 spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node + name: selenium-node-chrome-131 triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' + browserVersion: '131.0' + unsafeSsl : 'true' ``` -The above example will create Chrome browser nodes equal to the requests pending in session queue for Chrome browser. +The request to trigger this scaler should be + +```python +options = ChromeOptions() +options.set_capability('platformName', 'Linux') +options.set_capability('browserVersion', '131.0') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) +``` -Similarly for Firefox +Similarly, for Firefox ```yaml apiVersion: keda.sh/v1alpha1 kind: ScaledObject metadata: - name: selenium-grid-firefox-scaledobject + name: selenium-grid-scaledobject-firefox namespace: keda labels: - deploymentName: selenium-firefox-node + deploymentName: selenium-node-firefox spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-firefox-node + name: selenium-node-firefox triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'firefox' + unsafeSsl : 'true' ``` -Similarly for Edge. Note that for Edge you must set the `sessionBrowserName` to `msedge` inorder for scaling to work properly. +Request to trigger the scaler + +```python +options = FirefoxOptions() +options.set_capability('platformName', 'Linux') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) +``` + +Similarly, for Edge. Note that for Edge you must set the `sessionBrowserName` to `msedge` inorder for scaling to work properly. ```yaml apiVersion: keda.sh/v1alpha1 kind: ScaledObject metadata: - name: selenium-grid-edge-scaledobject + name: selenium-grid-scaledobject-edge namespace: keda labels: - deploymentName: selenium-edge-node + deploymentName: selenium-node-edge spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-edge-node + name: selenium-node-edge triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'MicrosoftEdge' sessionBrowserName: 'msedge' + platformName: 'Linux' + unsafeSsl : 'true' +``` + +Request to trigger the scaler + +```python +options = EdgeOptions() +options.set_capability('platformName', 'Linux') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) ``` In case you want to scale from 0 (`minReplicaCount: 0`), and browser nodes are configured different `--max-sessions` greater than 1, you can set `nodeMaxSessions` for scaler align with number of slots available per node to have the correct scaling behavior. @@ -121,17 +283,18 @@ metadata: name: selenium-grid-chrome-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node + deploymentName: selenium-node-chrome spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node + name: selenium-node-chrome triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' nodeMaxSessions: 4 + unsafeSsl : 'true' ``` If you are supporting multiple versions of browser capability in your Selenium Grid, You should create one scaler for every browser version and pass the `browserVersion` in the metadata. @@ -143,17 +306,18 @@ metadata: name: selenium-grid-chrome-91-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node-91 + deploymentName: selenium-node-chrome-91 spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node-91 + name: selenium-node-chrome-91 triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' browserVersion: '91.0' + unsafeSsl : 'true' ``` ```yaml @@ -163,17 +327,18 @@ metadata: name: selenium-grid-chrome-90-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node-90 + deploymentName: selenium-node-chrome-90 spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node-90 + name: selenium-node-chrome-90 triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' browserVersion: '90.0' + unsafeSsl : 'true' ``` ### Authentication Parameters @@ -219,15 +384,16 @@ metadata: name: selenium-grid-chrome-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node + deploymentName: selenium-node-chrome spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node + name: selenium-node-chrome triggers: - type: selenium-grid metadata: browserName: 'chrome' + unsafeSsl : 'true' authenticationRef: name: keda-trigger-auth-selenium-grid-secret ``` diff --git a/content/docs/2.17/scalers/selenium-grid-scaler.md b/content/docs/2.17/scalers/selenium-grid-scaler.md index 6ce9d281a..09cf38811 100644 --- a/content/docs/2.17/scalers/selenium-grid-scaler.md +++ b/content/docs/2.17/scalers/selenium-grid-scaler.md @@ -13,30 +13,31 @@ This specification describes the `selenium-grid` trigger that scales browser nod The scaler creates one browser node per pending request in session queue, divided by the max amount of sessions that can run in parallel. You will have to create one trigger per browser capability that you would like to support in your Selenium Grid. -The below is an example trigger configuration for chrome node. +The below is an example trigger configuration with default values. ```yaml triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' # Required. Can be ommitted if specified via TriggerAuthentication/ClusterTriggerAuthentication. - browserName: 'chrome' # Required - browserVersion: '91.0' # Optional. Only required when supporting multiple versions of browser in your Selenium Grid. - unsafeSsl : 'true' # Optional - activationThreshold: 5 # Optional - platformName: 'Linux' # Optional + browserName: '' # Optional. Required to be matched with the request in queue and Node stereotypes (Similarly for `browserVersion` and `platformName`). + browserVersion: '' # Optional. + platformName: 'linux' # Optional. + unsafeSsl : 'false' # Optional. + activationThreshold: 0 # Optional. ``` **Parameter list:** - `url` - Graphql url of your Selenium Grid. Refer to the Selenium Grid's documentation [here](https://www.selenium.dev/documentation/en/grid/grid_4/graphql_support/) to for more info. If endpoint requires authentication, you can use `TriggerAuthentication` to provide the credentials instead of embedding in the URL. -- `browserName` - Name of browser that usually gets passed in the browser capability. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. +- `browserName` - Name of browser that usually gets passed in the browser capability. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Optional) - `sessionBrowserName` - Name of the browser when it is an active session, only set if `BrowserName` changes between the queue and the active session. See the Edge example below for further detail. (Optional) - `browserVersion` - Version of browser that usually gets passed in the browser capability. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Optional) - `unsafeSsl` - Skip certificate validation when connecting over HTTPS. (Values: `true`, `false`, Default: `false`, Optional) - `activationThreshold` - Target value for activating the scaler. Learn more about activation [here](./../concepts/scaling-deployments.md#activating-and-scaling-thresholds). (Default: `0`, Optional) - `platformName` - Name of the browser platform. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Default: `Linux`, Optional) - `nodeMaxSessions` - Number of maximum sessions that can run in parallel on a Node. Update this parameter align with node config `--max-sessions` (`SE_NODE_MAX_SESSIONS`) to have the correct scaling behavior. (Default: `1`, Optional). +- `targetQueueLength` - The target number of queued sessions to scale on. (Default: `1`, Optional). **Trigger Authentication** - `username` - Username for basic authentication in GraphQL endpoint instead of embedding in the URL. (Optional) @@ -44,72 +45,233 @@ triggers: - `authType` - Type of authentication to be used. This can be set to `Bearer` or `OAuth2` in case Selenium Grid behind an Ingress proxy with other authentication types. (Optional) - `accessToken` - Access token. This is required when `authType` is set a value. (Optional) +### How does it work? + +The scaler will query the Hub GraphQL response to get the number of queued sessions in the specified combination of browser name, version, and platform. If the number of queued sessions is **equal to or greater than** the `targetQueueLength`, the scaler will scale up. + ### Example Here is a full example of scaled object definition using Selenium Grid trigger: ```yaml +kind: Deployment +metadata: + name: selenium-node-chrome + labels: + deploymentName: selenium-node-chrome +spec: + replicas: 1 + template: + spec: + containers: + - name: selenium-node-chrome + image: selenium/node-chrome:latest + ports: + - containerPort: 5555 + env: + - name: SE_NODE_BROWSER_VERSION + value: "" + +--- + apiVersion: keda.sh/v1alpha1 kind: ScaledObject metadata: - name: selenium-grid-chrome-scaledobject + name: selenium-grid-scaledobject-chrome + namespace: keda + labels: + deploymentName: selenium-node-chrome +spec: + maxReplicaCount: 8 + scaleTargetRef: + name: selenium-node-chrome + triggers: + - type: selenium-grid + metadata: + url: 'http://selenium-hub:4444/graphql' + browserName: 'chrome' + unsafeSsl : 'true' +``` + +Noted: +- From `v2.16.1+`, the trigger metadata `browserVersion`, `platformName` is recommended to be set explicitly to have the correct scaling behavior (especially when your Grid includes autoscaling Nodes, non-autoscaling Nodes, relay Nodes, etc.). Besides that, in client binding, it is also recommended to set the `browserVersion`, `platformName` to align with the trigger metadata. Please see below examples for more details. + +The above example will create Chrome browser nodes equal to the requests pending in session queue for Chrome browser, which is created from client. For example in Python binding + +```python +options = ChromeOptions() +options.set_capability('platformName', 'Linux') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) +``` + +With above script, the request is sent to Grid. Via GraphQL response, it looks like + +```json +{ + "data": { + "grid": { + "sessionCount": 0, + "maxSession": 0, + "totalSlots": 0 + }, + "nodesInfo": { + "nodes": [] + }, + "sessionsInfo": { + "sessionQueueRequests": [ + "{\"browserName\": \"chrome\", \"platformName\": \"linux\"}" + ] + } + } +} +``` + +In Node deployment spec, there is environment variable `SE_NODE_BROWSER_VERSION` which is set to empty. This is used to unset `browserVersion` in Node stereotypes (it is in project [docker-selenium](https://github.com/SeleniumHQ/docker-selenium) setting short browser build number by default), which is expected to match with the request capabilities in queue and scaler trigger metadata. + +When the request capabilities match with scaler trigger metadata, the scaler will create a new Node and connect to the Hub. Now the GraphQL response looks like + +```json +{ + "data": { + "grid": { + "sessionCount": 0, + "maxSession": 1, + "totalSlots": 1 + }, + "nodesInfo": { + "nodes": [ + { + "id": "UUID-of-Node", + "status": "UP", + "sessionCount": 0, + "maxSession": 1, + "slotCount": 1, + "stereotypes": "[{\"slots\": 1, \"stereotype\": {\"browserName\": \"chrome\", \"browserVersion\": \"\", \"platformName\": \"Linux\"}}]", + "sessions": [] + } + ] + }, + "sessionsInfo": { + "sessionQueueRequests": [ + "{\"browserName\": \"chrome\", \"platformName\": \"linux\"}" + ] + } + } +} +``` + +Now, the request can be picked up by the Node and the session is created. Session queue will be cleared and the scaler will not create a new Node until the next request comes in. + +Moreover, at the same time, you can create one more scaled object for Chrome browser request with specific `browserVersion`. For example + +```yaml +kind: Deployment +metadata: + name: selenium-node-chrome-131 + labels: + deploymentName: selenium-node-chrome-131 +spec: + replicas: 1 + template: + spec: + containers: + - name: selenium-node-chrome + image: selenium/node-chrome:131.0 + ports: + - containerPort: 5555 + +--- + +apiVersion: keda.sh/v1alpha1 +kind: ScaledObject +metadata: + name: selenium-grid-scaledobject-chrome-131 namespace: keda labels: - deploymentName: selenium-chrome-node + deploymentName: selenium-node-chrome-131 spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node + name: selenium-node-chrome-131 triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' + browserVersion: '131.0' + unsafeSsl : 'true' ``` -The above example will create Chrome browser nodes equal to the requests pending in session queue for Chrome browser. +The request to trigger this scaler should be + +```python +options = ChromeOptions() +options.set_capability('platformName', 'Linux') +options.set_capability('browserVersion', '131.0') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) +``` -Similarly for Firefox +Similarly, for Firefox ```yaml apiVersion: keda.sh/v1alpha1 kind: ScaledObject metadata: - name: selenium-grid-firefox-scaledobject + name: selenium-grid-scaledobject-firefox namespace: keda labels: - deploymentName: selenium-firefox-node + deploymentName: selenium-node-firefox spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-firefox-node + name: selenium-node-firefox triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'firefox' + unsafeSsl : 'true' ``` -Similarly for Edge. Note that for Edge you must set the `sessionBrowserName` to `msedge` inorder for scaling to work properly. +Request to trigger the scaler + +```python +options = FirefoxOptions() +options.set_capability('platformName', 'Linux') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) +``` + +Similarly, for Edge. Note that for Edge you must set the `sessionBrowserName` to `msedge` inorder for scaling to work properly. ```yaml apiVersion: keda.sh/v1alpha1 kind: ScaledObject metadata: - name: selenium-grid-edge-scaledobject + name: selenium-grid-scaledobject-edge namespace: keda labels: - deploymentName: selenium-edge-node + deploymentName: selenium-node-edge spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-edge-node + name: selenium-node-edge triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'MicrosoftEdge' sessionBrowserName: 'msedge' + platformName: 'Linux' + unsafeSsl : 'true' +``` + +Request to trigger the scaler + +```python +options = EdgeOptions() +options.set_capability('platformName', 'Linux') +driver = webdriver.Remote(options=options, command_executor=SELENIUM_GRID_URL) ``` In case you want to scale from 0 (`minReplicaCount: 0`), and browser nodes are configured different `--max-sessions` greater than 1, you can set `nodeMaxSessions` for scaler align with number of slots available per node to have the correct scaling behavior. @@ -121,17 +283,18 @@ metadata: name: selenium-grid-chrome-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node + deploymentName: selenium-node-chrome spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node + name: selenium-node-chrome triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' nodeMaxSessions: 4 + unsafeSsl : 'true' ``` If you are supporting multiple versions of browser capability in your Selenium Grid, You should create one scaler for every browser version and pass the `browserVersion` in the metadata. @@ -143,17 +306,18 @@ metadata: name: selenium-grid-chrome-91-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node-91 + deploymentName: selenium-node-chrome-91 spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node-91 + name: selenium-node-chrome-91 triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' browserVersion: '91.0' + unsafeSsl : 'true' ``` ```yaml @@ -163,17 +327,18 @@ metadata: name: selenium-grid-chrome-90-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node-90 + deploymentName: selenium-node-chrome-90 spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node-90 + name: selenium-node-chrome-90 triggers: - type: selenium-grid metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' browserVersion: '90.0' + unsafeSsl : 'true' ``` ### Authentication Parameters @@ -219,15 +384,16 @@ metadata: name: selenium-grid-chrome-scaledobject namespace: keda labels: - deploymentName: selenium-chrome-node + deploymentName: selenium-node-chrome spec: maxReplicaCount: 8 scaleTargetRef: - name: selenium-chrome-node + name: selenium-node-chrome triggers: - type: selenium-grid metadata: browserName: 'chrome' + unsafeSsl : 'true' authenticationRef: name: keda-trigger-auth-selenium-grid-secret ``` From 318903138387c126bc0e31f6d40e4a1c984312ab Mon Sep 17 00:00:00 2001 From: Viet Nguyen Duc Date: Tue, 24 Dec 2024 02:57:48 +0700 Subject: [PATCH 2/2] Fix review comment Signed-off-by: Viet Nguyen Duc --- content/docs/2.16/scalers/selenium-grid-scaler.md | 11 ++++++----- content/docs/2.17/scalers/selenium-grid-scaler.md | 15 ++++++++------- 2 files changed, 14 insertions(+), 12 deletions(-) diff --git a/content/docs/2.16/scalers/selenium-grid-scaler.md b/content/docs/2.16/scalers/selenium-grid-scaler.md index 4843d3d84..b06321d58 100644 --- a/content/docs/2.16/scalers/selenium-grid-scaler.md +++ b/content/docs/2.16/scalers/selenium-grid-scaler.md @@ -37,7 +37,6 @@ triggers: - `activationThreshold` - Target value for activating the scaler. Learn more about activation [here](./../concepts/scaling-deployments.md#activating-and-scaling-thresholds). (Default: `0`, Optional) - `platformName` - Name of the browser platform. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Default: `Linux`, Optional) - `nodeMaxSessions` - Number of maximum sessions that can run in parallel on a Node. Update this parameter align with node config `--max-sessions` (`SE_NODE_MAX_SESSIONS`) to have the correct scaling behavior. (Default: `1`, Optional). -- `targetQueueLength` - The target number of queued sessions to scale on. (Default: `1`, Optional). **Trigger Authentication** - `username` - Username for basic authentication in GraphQL endpoint instead of embedding in the URL. (Optional) @@ -45,10 +44,6 @@ triggers: - `authType` - Type of authentication to be used. This can be set to `Bearer` or `OAuth2` in case Selenium Grid behind an Ingress proxy with other authentication types. (Optional) - `accessToken` - Access token. This is required when `authType` is set a value. (Optional) -### How does it work? - -The scaler will query the Hub GraphQL response to get the number of queued sessions in the specified combination of browser name, version, and platform. If the number of queued sessions is **equal to or greater than** the `targetQueueLength`, the scaler will scale up. - ### Example Here is a full example of scaled object definition using Selenium Grid trigger: @@ -90,6 +85,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' unsafeSsl : 'true' ``` @@ -231,6 +227,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'firefox' + platformName: 'Linux' unsafeSsl : 'true' ``` @@ -293,6 +290,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' nodeMaxSessions: 4 unsafeSsl : 'true' ``` @@ -316,6 +314,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' browserVersion: '91.0' unsafeSsl : 'true' ``` @@ -337,6 +336,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' browserVersion: '90.0' unsafeSsl : 'true' ``` @@ -393,6 +393,7 @@ spec: - type: selenium-grid metadata: browserName: 'chrome' + platformName: 'Linux' unsafeSsl : 'true' authenticationRef: name: keda-trigger-auth-selenium-grid-secret diff --git a/content/docs/2.17/scalers/selenium-grid-scaler.md b/content/docs/2.17/scalers/selenium-grid-scaler.md index 09cf38811..b06321d58 100644 --- a/content/docs/2.17/scalers/selenium-grid-scaler.md +++ b/content/docs/2.17/scalers/selenium-grid-scaler.md @@ -13,7 +13,7 @@ This specification describes the `selenium-grid` trigger that scales browser nod The scaler creates one browser node per pending request in session queue, divided by the max amount of sessions that can run in parallel. You will have to create one trigger per browser capability that you would like to support in your Selenium Grid. -The below is an example trigger configuration with default values. +The below is an example trigger configuration with default values represent. ```yaml triggers: @@ -37,7 +37,6 @@ triggers: - `activationThreshold` - Target value for activating the scaler. Learn more about activation [here](./../concepts/scaling-deployments.md#activating-and-scaling-thresholds). (Default: `0`, Optional) - `platformName` - Name of the browser platform. Refer to the [Selenium Grid's](https://www.selenium.dev/documentation/en/getting_started_with_webdriver/browsers/) and [WebdriverIO's](https://webdriver.io/docs/options/#capabilities) documentation for more info. (Default: `Linux`, Optional) - `nodeMaxSessions` - Number of maximum sessions that can run in parallel on a Node. Update this parameter align with node config `--max-sessions` (`SE_NODE_MAX_SESSIONS`) to have the correct scaling behavior. (Default: `1`, Optional). -- `targetQueueLength` - The target number of queued sessions to scale on. (Default: `1`, Optional). **Trigger Authentication** - `username` - Username for basic authentication in GraphQL endpoint instead of embedding in the URL. (Optional) @@ -45,10 +44,6 @@ triggers: - `authType` - Type of authentication to be used. This can be set to `Bearer` or `OAuth2` in case Selenium Grid behind an Ingress proxy with other authentication types. (Optional) - `accessToken` - Access token. This is required when `authType` is set a value. (Optional) -### How does it work? - -The scaler will query the Hub GraphQL response to get the number of queued sessions in the specified combination of browser name, version, and platform. If the number of queued sessions is **equal to or greater than** the `targetQueueLength`, the scaler will scale up. - ### Example Here is a full example of scaled object definition using Selenium Grid trigger: @@ -70,7 +65,7 @@ spec: - containerPort: 5555 env: - name: SE_NODE_BROWSER_VERSION - value: "" + value: '' --- @@ -90,6 +85,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' unsafeSsl : 'true' ``` @@ -231,6 +227,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'firefox' + platformName: 'Linux' unsafeSsl : 'true' ``` @@ -293,6 +290,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' nodeMaxSessions: 4 unsafeSsl : 'true' ``` @@ -316,6 +314,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' browserVersion: '91.0' unsafeSsl : 'true' ``` @@ -337,6 +336,7 @@ spec: metadata: url: 'http://selenium-hub:4444/graphql' browserName: 'chrome' + platformName: 'Linux' browserVersion: '90.0' unsafeSsl : 'true' ``` @@ -393,6 +393,7 @@ spec: - type: selenium-grid metadata: browserName: 'chrome' + platformName: 'Linux' unsafeSsl : 'true' authenticationRef: name: keda-trigger-auth-selenium-grid-secret