pkg/clients/ssl/fake.go (88 lines of code) (raw):
/*
Copyright 2020 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
https://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 ssl
import (
"context"
computev1 "google.golang.org/api/compute/v1"
"github.com/GoogleCloudPlatform/gke-managed-certs/pkg/utils/errors"
)
func newFakeError(code string) *Error {
return &Error{
operation: &computev1.Operation{
Error: &computev1.OperationError{
Errors: []*computev1.OperationErrorErrors{{Code: code}},
},
},
}
}
func NewFakeQuotaExceededError() *Error {
return newFakeError(codeQuotaExceeded)
}
func NewFakeSslCertificate(name, status string, domainToStatus map[string]string) *computev1.SslCertificate {
var domains []string
for domain := range domainToStatus {
domains = append(domains, domain)
}
return &computev1.SslCertificate{
Managed: &computev1.SslCertificateManagedSslCertificate{
Domains: domains,
Status: status,
DomainStatus: domainToStatus,
},
Name: name,
Type: typeManaged,
}
}
// Fake
type Fake struct {
mapping map[string]*computev1.SslCertificate
}
var _ Interface = &Fake{}
func (f *Fake) Create(ctx context.Context, name string, domains []string) error {
domainToStatus := make(map[string]string, 0)
for _, domain := range domains {
domainToStatus[domain] = ""
}
f.mapping[name] = NewFakeSslCertificate(name, "", domainToStatus)
return nil
}
func (f *Fake) Delete(ctx context.Context, name string) error {
if _, e := f.mapping[name]; !e {
return errors.NotFound
}
delete(f.mapping, name)
return nil
}
func (f *Fake) Get(name string) (*computev1.SslCertificate, error) {
if _, e := f.mapping[name]; !e {
return nil, errors.NotFound
}
return f.mapping[name], nil
}
func (f *Fake) List() ([]*computev1.SslCertificate, error) {
var result []*computev1.SslCertificate
for _, v := range f.mapping {
result = append(result, v)
}
return result, nil
}
// Builder
type Builder struct {
fake *Fake
}
func NewFake() *Builder {
return &Builder{
fake: &Fake{mapping: make(map[string]*computev1.SslCertificate, 0)},
}
}
func (b *Builder) AddEntry(name string, domains []string) *Builder {
domainToStatus := make(map[string]string, 0)
for _, domain := range domains {
domainToStatus[domain] = ""
}
b.fake.mapping[name] = NewFakeSslCertificate(name, "", domainToStatus)
return b
}
func (b *Builder) AddEntryWithStatus(name, status string, domainToStatus map[string]string) *Builder {
b.fake.mapping[name] = NewFakeSslCertificate(name, status, domainToStatus)
return b
}
func (b *Builder) Build() Interface {
return b.fake
}