blob: 3bc5aa0e2c64a45034aabd96bc8a13a38b27071c [file] [log] [blame]
// Copyright 2023 Google LLC
//
// 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 idtoken
import (
"context"
"encoding/json"
"fmt"
"net/http"
"net/http/httptest"
"os"
"testing"
"cloud.google.com/go/auth/internal"
"cloud.google.com/go/auth/internal/credsfile"
)
func TestNewCredentials_ServiceAccount(t *testing.T) {
wantTok, _ := createRS256JWT(t)
b, err := os.ReadFile("../../internal/testdata/sa.json")
if err != nil {
t.Fatal(err)
}
f, err := credsfile.ParseServiceAccount(b)
if err != nil {
t.Fatal(err)
}
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) {
w.Header().Set("Content-Type", "application/json")
w.Write([]byte(fmt.Sprintf(`{"id_token": "%s"}`, wantTok)))
}))
defer ts.Close()
f.TokenURL = ts.URL
b, err = json.Marshal(f)
if err != nil {
t.Fatal(err)
}
creds, err := NewCredentials(&Options{
Audience: "aud",
CredentialsJSON: b,
CustomClaims: map[string]interface{}{
"foo": "bar",
},
})
if err != nil {
t.Fatal(err)
}
tok, err := creds.Token(context.Background())
if err != nil {
t.Fatalf("tp.Token() = %v", err)
}
if tok.Value != wantTok {
t.Errorf("got %q, want %q", tok.Value, wantTok)
}
}
type mockTransport struct {
handler http.HandlerFunc
}
func (m mockTransport) RoundTrip(r *http.Request) (*http.Response, error) {
rw := httptest.NewRecorder()
m.handler(rw, r)
return rw.Result(), nil
}
func TestNewCredentials_ImpersonatedServiceAccount(t *testing.T) {
wantTok, _ := createRS256JWT(t)
client := internal.CloneDefaultClient()
client.Transport = mockTransport{
handler: http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.Write([]byte(fmt.Sprintf(`{"token": %q}`, wantTok)))
}),
}
creds, err := NewCredentials(&Options{
Audience: "aud",
CredentialsFile: "../../internal/testdata/imp.json",
CustomClaims: map[string]interface{}{
"foo": "bar",
},
Client: client,
})
if err != nil {
t.Fatal(err)
}
tok, err := creds.Token(context.Background())
if err != nil {
t.Fatalf("tp.Token() = %v", err)
}
if tok.Value != wantTok {
t.Errorf("got %q, want %q", tok.Value, wantTok)
}
}