Skip to content

Commit

Permalink
Refactor GrantPermissionOptions parsing to mapping
Browse files Browse the repository at this point in the history
- Turns GrantPermissionsOptions to a value type from a pointer as this
  type is not need to be used to be mutated.
- Moves Sobek transformation to the mapping layer.
- Errors out if an incorrect option is given. This way we don't surprise
  users and train them to use the API correctly. Otherwise, hiding these
  errors might lead to unexpected issues.
  • Loading branch information
inancgumus committed Nov 5, 2024
1 parent 85c37b7 commit e2fb899
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 32 deletions.
30 changes: 26 additions & 4 deletions browser/browser_context_mapping.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package browser

import (
"context"
"errors"
"fmt"
"reflect"
Expand Down Expand Up @@ -76,10 +77,11 @@ func mapBrowserContext(vu moduleVU, bc *common.BrowserContext) mapping { //nolin
},
"grantPermissions": func(permissions []string, opts sobek.Value) *sobek.Promise {
return k6ext.Promise(vu.Context(), func() (any, error) {
popts := common.NewGrantPermissionsOptions()
popts.Parse(vu.Context(), opts)

return nil, bc.GrantPermissions(permissions, popts) //nolint:wrapcheck
popts, err := parseGrantPermissionOptions(vu.Context(), opts)
if err != nil {
return nil, fmt.Errorf("parsing grant permission options: %w", err)
}
return nil, bc.GrantPermissions(permissions, popts)
})
},
"setDefaultNavigationTimeout": bc.SetDefaultNavigationTimeout,
Expand Down Expand Up @@ -185,3 +187,23 @@ func mapBrowserContext(vu moduleVU, bc *common.BrowserContext) mapping { //nolin
},
}
}

// parseGrantPermissionOptions parses the options for the browserContext.grantPermissions API.
func parseGrantPermissionOptions(ctx context.Context, opts sobek.Value) (common.GrantPermissionsOptions, error) {
if !sobekValueExists(opts) {
return common.GrantPermissionsOptions{}, nil
}

var g common.GrantPermissionsOptions

o := opts.ToObject(k6ext.Runtime(ctx))
for _, k := range o.Keys() {
if k == "origin" {
g.Origin = o.Get(k).String()
continue
}
return common.GrantPermissionsOptions{}, fmt.Errorf("unknown option: %s", k)
}

return g, nil
}
9 changes: 5 additions & 4 deletions browser/sync_browser_context_mapping.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,10 +49,11 @@ func syncMapBrowserContext(vu moduleVU, bc *common.BrowserContext) mapping { //n
"close": bc.Close,
"cookies": bc.Cookies,
"grantPermissions": func(permissions []string, opts sobek.Value) error {
pOpts := common.NewGrantPermissionsOptions()
pOpts.Parse(vu.Context(), opts)

return bc.GrantPermissions(permissions, pOpts) //nolint:wrapcheck
popts, err := parseGrantPermissionOptions(vu.Context(), opts)
if err != nil {
return fmt.Errorf("parsing grant permission options: %w", err)
}
return bc.GrantPermissions(permissions, popts)
},
"setDefaultNavigationTimeout": bc.SetDefaultNavigationTimeout,
"setDefaultTimeout": bc.SetDefaultTimeout,
Expand Down
4 changes: 2 additions & 2 deletions common/browser_context.go
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ func NewBrowserContext(
}

if len(opts.Permissions) > 0 {
err := b.GrantPermissions(opts.Permissions, NewGrantPermissionsOptions())
err := b.GrantPermissions(opts.Permissions, GrantPermissionsOptions{})
if err != nil {
return nil, err
}
Expand Down Expand Up @@ -206,7 +206,7 @@ func (b *BrowserContext) Close() error {
}

// GrantPermissions enables the specified permissions, all others will be disabled.
func (b *BrowserContext) GrantPermissions(permissions []string, opts *GrantPermissionsOptions) error {
func (b *BrowserContext) GrantPermissions(permissions []string, opts GrantPermissionsOptions) error {
b.logger.Debugf("BrowserContext:GrantPermissions", "bctxid:%v", b.id)

permsToProtocol := map[string]cdpbrowser.PermissionType{
Expand Down
20 changes: 0 additions & 20 deletions common/browser_context_options.go
Original file line number Diff line number Diff line change
Expand Up @@ -150,23 +150,3 @@ func (w *WaitForEventOptions) Parse(ctx context.Context, optsOrPredicate sobek.V
type GrantPermissionsOptions struct {
Origin string
}

// NewGrantPermissionsOptions returns a new GrantPermissionsOptions.
func NewGrantPermissionsOptions() *GrantPermissionsOptions {
return &GrantPermissionsOptions{}
}

// Parse parses the options from opts if opts exists in the sobek runtime.
func (g *GrantPermissionsOptions) Parse(ctx context.Context, opts sobek.Value) {
rt := k6ext.Runtime(ctx)

if sobekValueExists(opts) {
opts := opts.ToObject(rt)
for _, k := range opts.Keys() {
if k == "origin" {
g.Origin = opts.Get(k).String()
break
}
}
}
}
10 changes: 8 additions & 2 deletions tests/browser_context_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -912,7 +912,10 @@ func TestBrowserContextGrantPermissions(t *testing.T) {
bCtx, err := tb.NewContext(nil)
require.NoError(t, err)

err = bCtx.GrantPermissions([]string{tc.permission}, common.NewGrantPermissionsOptions())
err = bCtx.GrantPermissions(
[]string{tc.permission},
common.GrantPermissionsOptions{},
)

if tc.wantErr == "" {
assert.NoError(t, err)
Expand Down Expand Up @@ -968,7 +971,10 @@ func TestBrowserContextClearPermissions(t *testing.T) {

require.False(t, hasPermission(tb, p, "geolocation"))

err = bCtx.GrantPermissions([]string{"geolocation"}, common.NewGrantPermissionsOptions())
err = bCtx.GrantPermissions(
[]string{"geolocation"},
common.GrantPermissionsOptions{},
)
require.NoError(t, err)
require.True(t, hasPermission(tb, p, "geolocation"))

Expand Down

0 comments on commit e2fb899

Please sign in to comment.