forked from TrueCloudLab/distribution
175 lines
3.6 KiB
Go
175 lines
3.6 KiB
Go
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"flag"
|
|
"io/ioutil"
|
|
"path/filepath"
|
|
"testing"
|
|
)
|
|
|
|
var updateGolden = flag.Bool("update_golden", false, "If true, causes TestAPIs to update golden files")
|
|
|
|
func TestAPIs(t *testing.T) {
|
|
names := []string{
|
|
"any",
|
|
"arrayofarray-1",
|
|
"arrayofenum",
|
|
"arrayofmapofobjects",
|
|
"arrayofmapofstrings",
|
|
"blogger-3",
|
|
"getwithoutbody",
|
|
"mapofany",
|
|
"mapofarrayofobjects",
|
|
"mapofobjects",
|
|
"mapofstrings-1",
|
|
"quotednum",
|
|
"resource-named-service", // blogger/v3/blogger-api.json + s/BlogUserInfo/Service/
|
|
"unfortunatedefaults",
|
|
"variants",
|
|
"wrapnewlines",
|
|
}
|
|
for _, name := range names {
|
|
api, err := apiFromFile(filepath.Join("testdata", name+".json"))
|
|
if err != nil {
|
|
t.Errorf("Error loading API testdata/%s.json: %v", name, err)
|
|
continue
|
|
}
|
|
clean, err := api.GenerateCode()
|
|
if err != nil {
|
|
t.Errorf("Error generating code for %s: %v", name, err)
|
|
continue
|
|
}
|
|
goldenFile := filepath.Join("testdata", name+".want")
|
|
if *updateGolden {
|
|
if err := ioutil.WriteFile(goldenFile, clean, 0644); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
want, err := ioutil.ReadFile(goldenFile)
|
|
if err != nil {
|
|
t.Error(err)
|
|
continue
|
|
}
|
|
if !bytes.Equal(want, clean) {
|
|
tf, _ := ioutil.TempFile("", "api-"+name+"-got-json.")
|
|
tf.Write(clean)
|
|
tf.Close()
|
|
t.Errorf("Output for API %s differs: diff -u %s %s", name, goldenFile, tf.Name())
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestScope(t *testing.T) {
|
|
tests := [][]string{
|
|
{
|
|
"https://www.googleapis.com/auth/somescope",
|
|
"SomescopeScope",
|
|
},
|
|
{
|
|
"https://mail.google.com/somescope",
|
|
"MailGoogleComSomescopeScope",
|
|
},
|
|
{
|
|
"https://mail.google.com/",
|
|
"MailGoogleComScope",
|
|
},
|
|
}
|
|
for _, test := range tests {
|
|
if got := scopeIdentifierFromURL(test[0]); got != test[1] {
|
|
t.Errorf("scopeIdentifierFromURL(%q) got %q, want %q", test[0], got, test[1])
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestDepunct(t *testing.T) {
|
|
tests := []struct {
|
|
needCap bool
|
|
in, want string
|
|
}{
|
|
{
|
|
needCap: true,
|
|
in: "part__description",
|
|
want: "Part__description",
|
|
},
|
|
{
|
|
needCap: true,
|
|
in: "Part_description",
|
|
want: "PartDescription",
|
|
},
|
|
{
|
|
needCap: false,
|
|
in: "part_description",
|
|
want: "partDescription",
|
|
},
|
|
{
|
|
needCap: false,
|
|
in: "part-description",
|
|
want: "partDescription",
|
|
},
|
|
{
|
|
needCap: false,
|
|
in: "part.description",
|
|
want: "partDescription",
|
|
},
|
|
{
|
|
needCap: false,
|
|
in: "part$description",
|
|
want: "partDescription",
|
|
},
|
|
{
|
|
needCap: false,
|
|
in: "part/description",
|
|
want: "partDescription",
|
|
},
|
|
{
|
|
needCap: true,
|
|
in: "Part__description_name",
|
|
want: "Part__descriptionName",
|
|
},
|
|
{
|
|
needCap: true,
|
|
in: "Part_description_name",
|
|
want: "PartDescriptionName",
|
|
},
|
|
{
|
|
needCap: true,
|
|
in: "Part__description__name",
|
|
want: "Part__description__name",
|
|
},
|
|
{
|
|
needCap: true,
|
|
in: "Part_description__name",
|
|
want: "PartDescription__name",
|
|
},
|
|
}
|
|
for _, test := range tests {
|
|
if got := depunct(test.in, test.needCap); got != test.want {
|
|
t.Errorf("depunct(%q,%v) = %q; want %q", test.in, test.needCap, got, test.want)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestRenameVersion(t *testing.T) {
|
|
tests := []struct {
|
|
version, want string
|
|
}{
|
|
{
|
|
version: "directory_v1",
|
|
want: "directory/v1",
|
|
},
|
|
{
|
|
version: "email_migration_v1",
|
|
want: "email_migration/v1",
|
|
},
|
|
{
|
|
version: "my_api_v1.2",
|
|
want: "my_api/v1.2",
|
|
},
|
|
}
|
|
for _, test := range tests {
|
|
if got := renameVersion(test.version); got != test.want {
|
|
t.Errorf("renameVersion(%q) = %q; want %q", test.version, got, test.want)
|
|
}
|
|
}
|
|
}
|