From 47288c57b0024b7304087d7ef6040436fdf9b302 Mon Sep 17 00:00:00 2001 From: Daniel Adam Date: Tue, 20 Aug 2024 11:49:43 +0200 Subject: [PATCH] Update measure memory test Set high threshold for memory usage, we want the test succeed and only fail if the memory usage increases dramatically. --- .github/workflows/measureMemory.yml | 80 ++++++++++++------------- device-provisioning-service/README.md | 1 + pkg/security/jwt/validator/validator.go | 4 +- 3 files changed, 43 insertions(+), 42 deletions(-) diff --git a/.github/workflows/measureMemory.yml b/.github/workflows/measureMemory.yml index e17375074..131a91a34 100644 --- a/.github/workflows/measureMemory.yml +++ b/.github/workflows/measureMemory.yml @@ -70,49 +70,49 @@ jobs: numDevices: 1 numResources: 1 resourceDataSize: 16384 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/1/size/1KB numDevices: 1 numResources: 1 resourceDataSize: 1024 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/125/size/16KB numDevices: 1 numResources: 125 resourceDataSize: 16384 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/125/size/1KB numDevices: 1 numResources: 125 resourceDataSize: 1024 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/250/size/16KB numDevices: 1 numResources: 250 resourceDataSize: 16384 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/250/size/1KB numDevices: 1 numResources: 250 resourceDataSize: 1024 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/500/size/16KB numDevices: 1 numResources: 500 resourceDataSize: 16384 - expectedRssInMb: 50 + expectedRssInMb: 100 timeout: 120m - name: devices/1/resources/500/size/1KB numDevices: 1 numResources: 500 resourceDataSize: 1024 - expectedRssInMb: 50 + expectedRssInMb: 100 logLevel: info logDumpBody: true timeout: 120m @@ -121,196 +121,196 @@ jobs: numDevices: 1000 numResources: 1 resourceDataSize: 16384 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/1/size/1KB numDevices: 1000 numResources: 1 resourceDataSize: 1024 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/125/size/16KB numDevices: 1000 numResources: 125 resourceDataSize: 16384 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/125/size/1KB numDevices: 1000 numResources: 125 resourceDataSize: 1024 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/250/size/16KB numDevices: 1000 numResources: 250 resourceDataSize: 16384 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/250/size/1KB numDevices: 1000 numResources: 250 resourceDataSize: 1024 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/500/size/16KB numDevices: 1000 numResources: 500 resourceDataSize: 16384 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m - name: devices/1000/resources/500/size/1KB numDevices: 1000 numResources: 500 resourceDataSize: 1024 - expectedRssInMb: 145 + expectedRssInMb: 250 timeout: 120m #2500 - name: devices/2500/resources/1/size/16KB numDevices: 2500 numResources: 1 resourceDataSize: 16384 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/1/size/1KB numDevices: 2500 numResources: 1 resourceDataSize: 1024 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/125/size/16KB numDevices: 2500 numResources: 125 resourceDataSize: 16384 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/125/size/1KB numDevices: 2500 numResources: 125 resourceDataSize: 1024 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/250/size/16KB numDevices: 2500 numResources: 250 resourceDataSize: 16384 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/250/size/1KB numDevices: 2500 numResources: 250 resourceDataSize: 1024 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/250/size/16KB numDevices: 2500 numResources: 500 resourceDataSize: 16384 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m - name: devices/2500/resources/500/size/1KB numDevices: 2500 numResources: 500 resourceDataSize: 1024 - expectedRssInMb: 210 + expectedRssInMb: 350 timeout: 120m #5000 - name: devices/5000/resources/1/size/16KB numDevices: 5000 numResources: 1 resourceDataSize: 16384 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/1/size/1KB numDevices: 5000 numResources: 1 resourceDataSize: 1024 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/125/size/16KB numDevices: 5000 numResources: 125 resourceDataSize: 16384 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/125/size/1KB numDevices: 5000 numResources: 125 resourceDataSize: 1024 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/250/size/16KB numDevices: 5000 numResources: 250 resourceDataSize: 16384 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/250/size/1KB numDevices: 5000 numResources: 250 resourceDataSize: 1024 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/500/size/16KB numDevices: 5000 numResources: 500 resourceDataSize: 16384 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m - name: devices/5000/resources/500/size/1KB numDevices: 5000 numResources: 500 resourceDataSize: 1024 - expectedRssInMb: 320 + expectedRssInMb: 500 timeout: 120m #10000 - name: devices/10000/resources/1/size/16KB numDevices: 10000 numResources: 1 resourceDataSize: 16384 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m - name: devices/10000/resources/1/size/1KB numDevices: 10000 numResources: 1 resourceDataSize: 1024 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m - name: devices/10000/resources/125/size/16KB numDevices: 10000 numResources: 125 resourceDataSize: 16384 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m - name: devices/10000/resources/125/size/1KB numDevices: 10000 numResources: 125 resourceDataSize: 1024 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m - name: devices/10000/resources/250/size/16KB numDevices: 10000 numResources: 250 resourceDataSize: 16384 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m - name: devices/10000/resources/250/size/1KB numDevices: 10000 numResources: 250 resourceDataSize: 1024 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m - name: devices/10000/resources/500/size/4KB numDevices: 10000 numResources: 500 resourceDataSize: 4096 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 300m - name: devices/10000/resources/500/size/1KB numDevices: 10000 numResources: 500 resourceDataSize: 1024 - expectedRssInMb: 530 + expectedRssInMb: 800 timeout: 120m # Steps represent a sequence of tasks that will be executed as part of the job diff --git a/device-provisioning-service/README.md b/device-provisioning-service/README.md index 698c846db..d68a4159e 100644 --- a/device-provisioning-service/README.md +++ b/device-provisioning-service/README.md @@ -76,6 +76,7 @@ The plgd device provisioning service REST API is defined by [swagger](https://ra | `apis.http.authorization.endpoints[].http.tls.keyFile` | string | `File path to private key in PEM format.` | `""` | | `apis.http.authorization.endpoints[].http.tls.certFile` | string | `File path to certificate in PEM format.` | `""` | | `apis.http.authorization.endpoints[].http.tls.useSystemCAPool` | bool | `If true, use system certification pool.` | `false` | +| `apis.http.authorization.tokenTrustVerification.cacheExpiration` | string | `Duration for which a valid token is kept in a runtime cache before re-verification is required.` | `30s` | | `apis.http.readTimeout` | string | `Maximum duration allowed for reading the entire request body, including the body by the server. A zero or negative value means there will be no timeout. Example: "8s" (8 seconds).` | `8s` | | `apis.http.readHeaderTimeout` | string | `The amount of time allowed to read request headers by the server. If readHeaderTimeout is zero, the value of readTimeout is used. If both are zero, there is no timeout.` | `4s` | | `apis.http.writeTimeout` | string | `The maximum duration before the server times out writing of the response. A zero or negative value means there will be no timeout.` | `16s` | diff --git a/pkg/security/jwt/validator/validator.go b/pkg/security/jwt/validator/validator.go index d1fd20e1e..f54e3389f 100644 --- a/pkg/security/jwt/validator/validator.go +++ b/pkg/security/jwt/validator/validator.go @@ -103,8 +103,8 @@ func New(ctx context.Context, config Config, fileWatcher *fsnotify.Watcher, logg keys.Add(issuer, openIDCfg.JWKSURL, httpClient.HTTP()) openIDConfigurations = append(openIDConfigurations, openIDCfg) if openIDCfg.PlgdTokensEndpoint != "" { - if opts, ok := options.customTokenIssuerClients[issuer]; ok { - clients[issuer] = opts + if tokenIssuer, ok := options.customTokenIssuerClients[issuer]; ok { + clients[issuer] = tokenIssuer continue } clients[issuer] = jwtValidator.NewHTTPClient(httpClient.HTTP(), openIDCfg.PlgdTokensEndpoint)