2016-12-28 01:45:11 +00:00
|
|
|
// Copyright 2016 clair authors
|
2016-01-19 20:16:45 +00:00
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
2015-12-28 20:03:29 +00:00
|
|
|
package pgsql
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2016-02-25 00:29:36 +00:00
|
|
|
|
2015-12-28 20:03:29 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
2016-05-02 22:33:03 +00:00
|
|
|
|
|
|
|
"github.com/coreos/clair/database"
|
2015-12-28 20:03:29 +00:00
|
|
|
)
|
|
|
|
|
2017-07-26 23:23:54 +00:00
|
|
|
func TestPersistNamespaces(t *testing.T) {
|
|
|
|
datastore, tx := openSessionForTest(t, "PersistNamespaces", false)
|
|
|
|
defer closeTest(t, datastore, tx)
|
|
|
|
|
|
|
|
ns1 := database.Namespace{}
|
|
|
|
ns2 := database.Namespace{Name: "t", VersionFormat: "b"}
|
2015-12-28 20:03:29 +00:00
|
|
|
|
2017-07-26 23:23:54 +00:00
|
|
|
// Empty Case
|
|
|
|
assert.Nil(t, tx.PersistNamespaces([]database.Namespace{}))
|
|
|
|
// Invalid Case
|
|
|
|
assert.NotNil(t, tx.PersistNamespaces([]database.Namespace{ns1}))
|
|
|
|
// Duplicated Case
|
|
|
|
assert.Nil(t, tx.PersistNamespaces([]database.Namespace{ns2, ns2}))
|
|
|
|
// Existing Case
|
|
|
|
assert.Nil(t, tx.PersistNamespaces([]database.Namespace{ns2}))
|
2015-12-28 20:03:29 +00:00
|
|
|
|
2017-07-26 23:23:54 +00:00
|
|
|
nsList := listNamespaces(t, tx)
|
|
|
|
assert.Len(t, nsList, 1)
|
|
|
|
assert.Equal(t, ns2, nsList[0])
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertNamespacesEqual(t *testing.T, expected []database.Namespace, actual []database.Namespace) bool {
|
|
|
|
if assert.Len(t, actual, len(expected)) {
|
|
|
|
has := map[database.Namespace]bool{}
|
|
|
|
for _, i := range expected {
|
|
|
|
has[i] = false
|
|
|
|
}
|
|
|
|
for _, i := range actual {
|
|
|
|
has[i] = true
|
|
|
|
}
|
|
|
|
for key, v := range has {
|
|
|
|
if !assert.True(t, v, key.Name+"is expected") {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
2015-12-28 20:03:29 +00:00
|
|
|
}
|
2016-01-28 16:26:34 +00:00
|
|
|
|
2017-07-26 23:23:54 +00:00
|
|
|
func listNamespaces(t *testing.T, tx *pgSession) []database.Namespace {
|
|
|
|
rows, err := tx.Query("SELECT name, version_format FROM namespace")
|
2016-01-28 16:26:34 +00:00
|
|
|
if err != nil {
|
2017-07-26 23:23:54 +00:00
|
|
|
t.FailNow()
|
2016-01-28 16:26:34 +00:00
|
|
|
}
|
2017-07-26 23:23:54 +00:00
|
|
|
defer rows.Close()
|
2016-01-28 16:26:34 +00:00
|
|
|
|
2017-07-26 23:23:54 +00:00
|
|
|
namespaces := []database.Namespace{}
|
|
|
|
for rows.Next() {
|
|
|
|
var ns database.Namespace
|
|
|
|
err := rows.Scan(&ns.Name, &ns.VersionFormat)
|
|
|
|
if err != nil {
|
|
|
|
t.FailNow()
|
2016-01-28 16:26:34 +00:00
|
|
|
}
|
2017-07-26 23:23:54 +00:00
|
|
|
namespaces = append(namespaces, ns)
|
2016-01-28 16:26:34 +00:00
|
|
|
}
|
2017-07-26 23:23:54 +00:00
|
|
|
|
|
|
|
return namespaces
|
2016-01-28 16:26:34 +00:00
|
|
|
}
|