// Copyright Project Harbor Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package repoproxy import ( "context" "testing" "github.com/goharbor/harbor/src/common/models" "github.com/goharbor/harbor/src/common/security" "github.com/goharbor/harbor/src/common/security/local" "github.com/goharbor/harbor/src/common/security/proxycachesecret" securitySecret "github.com/goharbor/harbor/src/common/security/secret" ) func TestIsProxySession(t *testing.T) { sc1 := securitySecret.NewSecurityContext("123456789", nil) otherCtx := security.NewContext(context.Background(), sc1) sc2 := proxycachesecret.NewSecurityContext("library/hello-world") proxyCtx := security.NewContext(context.Background(), sc2) user := &models.User{ Username: "robot$library+scanner-8ec3b47a-fd29-11ee-9681-0242c0a87009", } userSc := local.NewSecurityContext(user) scannerCtx := security.NewContext(context.Background(), userSc) otherRobot := &models.User{ Username: "robot$library+test-8ec3b47a-fd29-11ee-9681-0242c0a87009", } userSc2 := local.NewSecurityContext(otherRobot) nonScannerCtx := security.NewContext(context.Background(), userSc2) cases := []struct { name string in context.Context want bool }{ { name: `normal`, in: otherCtx, want: false, }, { name: `proxy user`, in: proxyCtx, want: true, }, { name: `robot account`, in: scannerCtx, want: true, }, { name: `non scanner robot`, in: nonScannerCtx, want: false, }, } for _, tt := range cases { t.Run(tt.name, func(t *testing.T) { got := isProxySession(tt.in, "library") if got != tt.want { t.Errorf(`(%v) = %v; want "%v"`, tt.in, got, tt.want) } }) } }