mirror of
https://github.com/Luzifer/nginx-sso.git
synced 2025-01-07 21:41:49 +00:00
174 lines
4.4 KiB
Go
174 lines
4.4 KiB
Go
|
// Copyright 2016 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 main
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
"time"
|
||
|
|
||
|
"cloud.google.com/go/bigtable"
|
||
|
"cloud.google.com/go/internal/testutil"
|
||
|
"github.com/google/go-cmp/cmp"
|
||
|
)
|
||
|
|
||
|
func TestParseDuration(t *testing.T) {
|
||
|
tests := []struct {
|
||
|
in string
|
||
|
// out or fail are mutually exclusive
|
||
|
out time.Duration
|
||
|
fail bool
|
||
|
}{
|
||
|
{in: "10ms", out: 10 * time.Millisecond},
|
||
|
{in: "3s", out: 3 * time.Second},
|
||
|
{in: "60m", out: 60 * time.Minute},
|
||
|
{in: "12h", out: 12 * time.Hour},
|
||
|
{in: "7d", out: 168 * time.Hour},
|
||
|
|
||
|
{in: "", fail: true},
|
||
|
{in: "0", fail: true},
|
||
|
{in: "7ns", fail: true},
|
||
|
{in: "14mo", fail: true},
|
||
|
{in: "3.5h", fail: true},
|
||
|
{in: "106752d", fail: true}, // overflow
|
||
|
}
|
||
|
for _, tc := range tests {
|
||
|
got, err := parseDuration(tc.in)
|
||
|
if !tc.fail && err != nil {
|
||
|
t.Errorf("parseDuration(%q) unexpectedly failed: %v", tc.in, err)
|
||
|
continue
|
||
|
}
|
||
|
if tc.fail && err == nil {
|
||
|
t.Errorf("parseDuration(%q) did not fail", tc.in)
|
||
|
continue
|
||
|
}
|
||
|
if tc.fail {
|
||
|
continue
|
||
|
}
|
||
|
if got != tc.out {
|
||
|
t.Errorf("parseDuration(%q) = %v, want %v", tc.in, got, tc.out)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestParseArgs(t *testing.T) {
|
||
|
got, err := parseArgs([]string{"a=1", "b=2"}, []string{"a", "b"})
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
want := map[string]string{"a": "1", "b": "2"}
|
||
|
if !testutil.Equal(got, want) {
|
||
|
t.Fatalf("got %v, want %v", got, want)
|
||
|
}
|
||
|
|
||
|
if _, err := parseArgs([]string{"a1"}, []string{"a1"}); err == nil {
|
||
|
t.Error("malformed: got nil, want error")
|
||
|
}
|
||
|
if _, err := parseArgs([]string{"a=1"}, []string{"b"}); err == nil {
|
||
|
t.Error("invalid: got nil, want error")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestParseColumnsFilter(t *testing.T) {
|
||
|
tests := []struct {
|
||
|
in string
|
||
|
out bigtable.Filter
|
||
|
fail bool
|
||
|
}{
|
||
|
{
|
||
|
in: "columnA",
|
||
|
out: bigtable.ColumnFilter("columnA"),
|
||
|
},
|
||
|
{
|
||
|
in: "familyA:columnA",
|
||
|
out: bigtable.ChainFilters(bigtable.FamilyFilter("familyA"), bigtable.ColumnFilter("columnA")),
|
||
|
},
|
||
|
{
|
||
|
in: "columnA,columnB",
|
||
|
out: bigtable.InterleaveFilters(bigtable.ColumnFilter("columnA"), bigtable.ColumnFilter("columnB")),
|
||
|
},
|
||
|
{
|
||
|
in: "familyA:columnA,columnB",
|
||
|
out: bigtable.InterleaveFilters(
|
||
|
bigtable.ChainFilters(bigtable.FamilyFilter("familyA"), bigtable.ColumnFilter("columnA")),
|
||
|
bigtable.ColumnFilter("columnB"),
|
||
|
),
|
||
|
},
|
||
|
{
|
||
|
in: "columnA,familyB:columnB",
|
||
|
out: bigtable.InterleaveFilters(
|
||
|
bigtable.ColumnFilter("columnA"),
|
||
|
bigtable.ChainFilters(bigtable.FamilyFilter("familyB"), bigtable.ColumnFilter("columnB")),
|
||
|
),
|
||
|
},
|
||
|
{
|
||
|
in: "familyA:columnA,familyB:columnB",
|
||
|
out: bigtable.InterleaveFilters(
|
||
|
bigtable.ChainFilters(bigtable.FamilyFilter("familyA"), bigtable.ColumnFilter("columnA")),
|
||
|
bigtable.ChainFilters(bigtable.FamilyFilter("familyB"), bigtable.ColumnFilter("columnB")),
|
||
|
),
|
||
|
},
|
||
|
{
|
||
|
in: "familyA:",
|
||
|
out: bigtable.FamilyFilter("familyA"),
|
||
|
},
|
||
|
{
|
||
|
in: ":columnA",
|
||
|
out: bigtable.ColumnFilter("columnA"),
|
||
|
},
|
||
|
{
|
||
|
in: ",:columnA,,familyB:columnB,",
|
||
|
out: bigtable.InterleaveFilters(
|
||
|
bigtable.ColumnFilter("columnA"),
|
||
|
bigtable.ChainFilters(bigtable.FamilyFilter("familyB"), bigtable.ColumnFilter("columnB")),
|
||
|
),
|
||
|
},
|
||
|
{
|
||
|
in: "familyA:columnA:cellA",
|
||
|
fail: true,
|
||
|
},
|
||
|
{
|
||
|
in: "familyA::columnA",
|
||
|
fail: true,
|
||
|
},
|
||
|
}
|
||
|
|
||
|
for _, tc := range tests {
|
||
|
got, err := parseColumnsFilter(tc.in)
|
||
|
|
||
|
if !tc.fail && err != nil {
|
||
|
t.Errorf("parseColumnsFilter(%q) unexpectedly failed: %v", tc.in, err)
|
||
|
continue
|
||
|
}
|
||
|
if tc.fail && err == nil {
|
||
|
t.Errorf("parseColumnsFilter(%q) did not fail", tc.in)
|
||
|
continue
|
||
|
}
|
||
|
if tc.fail {
|
||
|
continue
|
||
|
}
|
||
|
|
||
|
var cmpOpts cmp.Options
|
||
|
cmpOpts =
|
||
|
append(
|
||
|
cmpOpts,
|
||
|
cmp.AllowUnexported(bigtable.ChainFilters([]bigtable.Filter{}...)),
|
||
|
cmp.AllowUnexported(bigtable.InterleaveFilters([]bigtable.Filter{}...)))
|
||
|
|
||
|
if !cmp.Equal(got, tc.out, cmpOpts) {
|
||
|
t.Errorf("parseColumnsFilter(%q) = %v, want %v", tc.in, got, tc.out)
|
||
|
}
|
||
|
}
|
||
|
}
|