mirror of
https://github.com/goharbor/harbor.git
synced 2025-01-16 04:31:22 +01:00
Clean up tech debt codes
Clean up tech debt codes Signed-off-by: Wenkai Yin <yinw@vmware.com>
This commit is contained in:
parent
4492e47e89
commit
998e392bb4
@ -260,59 +260,6 @@ func TestGetOrmer(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAddRepository(t *testing.T) {
|
|
||||||
repoRecord := models.RepoRecord{
|
|
||||||
Name: currentProject.Name + "/" + repositoryName,
|
|
||||||
ProjectID: currentProject.ProjectID,
|
|
||||||
Description: "testing repo",
|
|
||||||
PullCount: 0,
|
|
||||||
StarCount: 0,
|
|
||||||
}
|
|
||||||
|
|
||||||
err := AddRepository(repoRecord)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Error occurred in AddRepository: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
newRepoRecord, err := GetRepositoryByName(currentProject.Name + "/" + repositoryName)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Error occurred in GetRepositoryByName: %v", err)
|
|
||||||
}
|
|
||||||
if newRepoRecord == nil {
|
|
||||||
t.Errorf("No repository found queried by repository name: %v", currentProject.Name+"/"+repositoryName)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var currentRepository *models.RepoRecord
|
|
||||||
|
|
||||||
func TestGetRepositoryByName(t *testing.T) {
|
|
||||||
var err error
|
|
||||||
currentRepository, err = GetRepositoryByName(currentProject.Name + "/" + repositoryName)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Error occurred in GetRepositoryByName: %v", err)
|
|
||||||
}
|
|
||||||
if currentRepository == nil {
|
|
||||||
t.Errorf("No repository found queried by repository name: %v", currentProject.Name+"/"+repositoryName)
|
|
||||||
}
|
|
||||||
if currentRepository.Name != currentProject.Name+"/"+repositoryName {
|
|
||||||
t.Errorf("Repository name does not match, expected: %s, actual: %s", currentProject.Name+"/"+repositoryName, currentProject.Name)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDeleteRepository(t *testing.T) {
|
|
||||||
err := DeleteRepository(currentRepository.Name)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Error occurred in DeleteRepository: %v", err)
|
|
||||||
}
|
|
||||||
repository, err := GetRepositoryByName(currentRepository.Name)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("Error occurred in GetRepositoryByName: %v", err)
|
|
||||||
}
|
|
||||||
if repository != nil {
|
|
||||||
t.Errorf("repository is not nil after deletion, repository: %+v", repository)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestIsDupRecError(t *testing.T) {
|
func TestIsDupRecError(t *testing.T) {
|
||||||
assert.True(t, IsDupRecErr(fmt.Errorf("pq: duplicate key value violates unique constraint \"properties_k_key\"")))
|
assert.True(t, IsDupRecErr(fmt.Errorf("pq: duplicate key value violates unique constraint \"properties_k_key\"")))
|
||||||
assert.False(t, IsDupRecErr(fmt.Errorf("other error")))
|
assert.False(t, IsDupRecErr(fmt.Errorf("other error")))
|
||||||
|
@ -1,91 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 dao
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"github.com/goharbor/harbor/src/lib/orm"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
)
|
|
||||||
|
|
||||||
// AddProjectMetadata adds metadata for a project
|
|
||||||
func AddProjectMetadata(meta *models.ProjectMetadata) error {
|
|
||||||
now := time.Now()
|
|
||||||
sql := `insert into project_metadata
|
|
||||||
(project_id, name, value, creation_time, update_time)
|
|
||||||
values (?, ?, ?, ?, ?)`
|
|
||||||
_, err := GetOrmer().Raw(sql, meta.ProjectID, meta.Name, meta.Value,
|
|
||||||
now, now).Exec()
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// DeleteProjectMetadata deleted metadata of a project. If name is absent
|
|
||||||
// all metadatas will be deleted, otherwise only the metadatas specified
|
|
||||||
// by name will be deleted
|
|
||||||
func DeleteProjectMetadata(projectID int64, name ...string) error {
|
|
||||||
params := make([]interface{}, 1)
|
|
||||||
sql := `delete from project_metadata
|
|
||||||
where project_id = ?`
|
|
||||||
params = append(params, projectID)
|
|
||||||
|
|
||||||
if len(name) > 0 {
|
|
||||||
sql += fmt.Sprintf(` and name in ( %s )`, orm.ParamPlaceholderForIn(len(name)))
|
|
||||||
params = append(params, name)
|
|
||||||
}
|
|
||||||
|
|
||||||
_, err := GetOrmer().Raw(sql, params).Exec()
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// UpdateProjectMetadata updates metadata of a project
|
|
||||||
func UpdateProjectMetadata(meta *models.ProjectMetadata) error {
|
|
||||||
sql := `update project_metadata
|
|
||||||
set value = ?, update_time = ?
|
|
||||||
where project_id = ? and name = ?`
|
|
||||||
_, err := GetOrmer().Raw(sql, meta.Value, time.Now(), meta.ProjectID,
|
|
||||||
meta.Name).Exec()
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetProjectMetadata returns the metadata of a project. If name is absent
|
|
||||||
// all metadatas will be returned, otherwise only the metadatas specified
|
|
||||||
// by name will be returned
|
|
||||||
func GetProjectMetadata(projectID int64, name ...string) ([]*models.ProjectMetadata, error) {
|
|
||||||
proMetas := []*models.ProjectMetadata{}
|
|
||||||
params := make([]interface{}, 1)
|
|
||||||
|
|
||||||
sql := `select * from project_metadata
|
|
||||||
where project_id = ? `
|
|
||||||
params = append(params, projectID)
|
|
||||||
|
|
||||||
if len(name) > 0 {
|
|
||||||
sql += fmt.Sprintf(` and name in ( %s )`, orm.ParamPlaceholderForIn(len(name)))
|
|
||||||
params = append(params, name)
|
|
||||||
}
|
|
||||||
|
|
||||||
_, err := GetOrmer().Raw(sql, params).QueryRows(&proMetas)
|
|
||||||
return proMetas, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// ListProjectMetadata ...
|
|
||||||
func ListProjectMetadata(name, value string) ([]*models.ProjectMetadata, error) {
|
|
||||||
sql := `select * from project_metadata
|
|
||||||
where name = ? and value = ? `
|
|
||||||
metadatas := []*models.ProjectMetadata{}
|
|
||||||
_, err := GetOrmer().Raw(sql, name, value).QueryRows(&metadatas)
|
|
||||||
return metadatas, err
|
|
||||||
}
|
|
@ -1,94 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 dao
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
"github.com/stretchr/testify/require"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestProMetaDaoMethods(t *testing.T) {
|
|
||||||
name1 := "key1"
|
|
||||||
value1 := "value1"
|
|
||||||
name2 := "key2"
|
|
||||||
value2 := "value2"
|
|
||||||
meta1 := &models.ProjectMetadata{
|
|
||||||
ProjectID: 1,
|
|
||||||
Name: name1,
|
|
||||||
Value: value1,
|
|
||||||
}
|
|
||||||
meta2 := &models.ProjectMetadata{
|
|
||||||
ProjectID: 1,
|
|
||||||
Name: name2,
|
|
||||||
Value: value2,
|
|
||||||
}
|
|
||||||
// test add
|
|
||||||
require.Nil(t, AddProjectMetadata(meta1))
|
|
||||||
defer func() {
|
|
||||||
// clean up
|
|
||||||
_, err := GetOrmer().Raw(`delete from project_metadata
|
|
||||||
where project_id = 1 and name = ?`, name1).Exec()
|
|
||||||
require.Nil(t, err)
|
|
||||||
}()
|
|
||||||
require.Nil(t, AddProjectMetadata(meta2))
|
|
||||||
defer func() {
|
|
||||||
// clean up
|
|
||||||
_, err := GetOrmer().Raw(`delete from project_metadata
|
|
||||||
where project_id = 1 and name = ?`, name2).Exec()
|
|
||||||
require.Nil(t, err)
|
|
||||||
}()
|
|
||||||
// test get
|
|
||||||
metas, err := GetProjectMetadata(1, name1, name2)
|
|
||||||
require.Nil(t, err)
|
|
||||||
assert.Equal(t, 2, len(metas))
|
|
||||||
|
|
||||||
m := map[string]*models.ProjectMetadata{}
|
|
||||||
for _, meta := range metas {
|
|
||||||
m[meta.Name] = meta
|
|
||||||
}
|
|
||||||
assert.Equal(t, value1, m[name1].Value)
|
|
||||||
assert.Equal(t, value2, m[name2].Value)
|
|
||||||
|
|
||||||
// test list
|
|
||||||
metas, err = ListProjectMetadata(name1, value1)
|
|
||||||
require.Nil(t, err)
|
|
||||||
assert.Equal(t, 1, len(metas))
|
|
||||||
assert.Equal(t, int64(1), metas[0].ProjectID)
|
|
||||||
|
|
||||||
// test update
|
|
||||||
newValue1 := "new_value1"
|
|
||||||
meta1.Value = newValue1
|
|
||||||
require.Nil(t, UpdateProjectMetadata(meta1))
|
|
||||||
metas, err = GetProjectMetadata(1, name1, name2)
|
|
||||||
require.Nil(t, err)
|
|
||||||
assert.Equal(t, 2, len(metas))
|
|
||||||
|
|
||||||
m = map[string]*models.ProjectMetadata{}
|
|
||||||
for _, meta := range metas {
|
|
||||||
m[meta.Name] = meta
|
|
||||||
}
|
|
||||||
assert.Equal(t, newValue1, m[name1].Value)
|
|
||||||
assert.Equal(t, value2, m[name2].Value)
|
|
||||||
|
|
||||||
// test delete
|
|
||||||
require.Nil(t, DeleteProjectMetadata(1, name1))
|
|
||||||
metas, err = GetProjectMetadata(1, name1, name2)
|
|
||||||
require.Nil(t, err)
|
|
||||||
assert.Equal(t, 1, len(metas))
|
|
||||||
assert.Equal(t, value2, metas[0].Value)
|
|
||||||
}
|
|
@ -1,127 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 dao
|
|
||||||
|
|
||||||
import (
|
|
||||||
"fmt"
|
|
||||||
"github.com/goharbor/harbor/src/common/utils"
|
|
||||||
libOrm "github.com/goharbor/harbor/src/lib/orm"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/astaxie/beego/orm"
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
)
|
|
||||||
|
|
||||||
var orderMap = map[string]string{
|
|
||||||
"name": "name asc",
|
|
||||||
"+name": "name asc",
|
|
||||||
"-name": "name desc",
|
|
||||||
"creation_time": "creation_time asc",
|
|
||||||
"+creation_time": "creation_time asc",
|
|
||||||
"-creation_time": "creation_time desc",
|
|
||||||
"update_time": "update_time asc",
|
|
||||||
"+update_time": "update_time asc",
|
|
||||||
"-update_time": "update_time desc",
|
|
||||||
"pull_count": "pull_count asc",
|
|
||||||
"+pull_count": "pull_count asc",
|
|
||||||
"-pull_count": "pull_count desc",
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddRepository adds a repo to the database.
|
|
||||||
func AddRepository(repo models.RepoRecord) error {
|
|
||||||
if repo.ProjectID == 0 {
|
|
||||||
return fmt.Errorf("invalid project ID: %d", repo.ProjectID)
|
|
||||||
}
|
|
||||||
|
|
||||||
o := GetOrmer()
|
|
||||||
now := time.Now()
|
|
||||||
repo.CreationTime = now
|
|
||||||
repo.UpdateTime = now
|
|
||||||
_, err := o.Insert(&repo)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetRepositoryByName ...
|
|
||||||
func GetRepositoryByName(name string) (*models.RepoRecord, error) {
|
|
||||||
o := GetOrmer()
|
|
||||||
r := models.RepoRecord{Name: name}
|
|
||||||
err := o.Read(&r, "Name")
|
|
||||||
if err == orm.ErrNoRows {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
return &r, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// DeleteRepository ...
|
|
||||||
func DeleteRepository(name string) error {
|
|
||||||
o := GetOrmer()
|
|
||||||
_, err := o.QueryTable("repository").Filter("name", name).Delete()
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// RepositoryExists returns whether the repository exists according to its name.
|
|
||||||
func RepositoryExists(name string) bool {
|
|
||||||
o := GetOrmer()
|
|
||||||
return o.QueryTable("repository").Filter("name", name).Exist()
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetTotalOfRepositories ...
|
|
||||||
func GetTotalOfRepositories(query ...*models.RepositoryQuery) (int64, error) {
|
|
||||||
sql, params := repositoryQueryConditions(query...)
|
|
||||||
sql = `select count(*) ` + sql
|
|
||||||
var total int64
|
|
||||||
if err := GetOrmer().Raw(sql, params).QueryRow(&total); err != nil {
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
return total, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func repositoryQueryConditions(query ...*models.RepositoryQuery) (string, []interface{}) {
|
|
||||||
params := []interface{}{}
|
|
||||||
sql := `from repository r `
|
|
||||||
if len(query) == 0 || query[0] == nil {
|
|
||||||
return sql, params
|
|
||||||
}
|
|
||||||
q := query[0]
|
|
||||||
|
|
||||||
if q.LabelID > 0 {
|
|
||||||
sql += `join harbor_resource_label rl on r.repository_id = rl.resource_id
|
|
||||||
and rl.resource_type = 'r' `
|
|
||||||
}
|
|
||||||
sql += `where 1=1 `
|
|
||||||
|
|
||||||
if len(q.Name) > 0 {
|
|
||||||
sql += `and r.name like ? `
|
|
||||||
params = append(params, "%"+libOrm.Escape(q.Name)+"%")
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(q.ProjectIDs) > 0 {
|
|
||||||
sql += fmt.Sprintf(`and r.project_id in ( %s ) `,
|
|
||||||
utils.ParamPlaceholderForIn(len(q.ProjectIDs)))
|
|
||||||
params = append(params, q.ProjectIDs)
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(q.ProjectName) > 0 {
|
|
||||||
sql += `and r.name like ? `
|
|
||||||
params = append(params, q.ProjectName+"/%")
|
|
||||||
}
|
|
||||||
|
|
||||||
if q.LabelID > 0 {
|
|
||||||
sql += `and rl.label_id = ? `
|
|
||||||
params = append(params, q.LabelID)
|
|
||||||
}
|
|
||||||
|
|
||||||
return sql, params
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 dao
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
"github.com/stretchr/testify/require"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
project = "library"
|
|
||||||
name = "library/repository-test"
|
|
||||||
repository = &models.RepoRecord{
|
|
||||||
Name: name,
|
|
||||||
ProjectID: 1,
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestGetTotalOfRepositories(t *testing.T) {
|
|
||||||
total, err := GetTotalOfRepositories()
|
|
||||||
require.Nil(t, err)
|
|
||||||
|
|
||||||
err = addRepository(repository)
|
|
||||||
require.Nil(t, err)
|
|
||||||
defer deleteRepository(name)
|
|
||||||
|
|
||||||
n, err := GetTotalOfRepositories()
|
|
||||||
require.Nil(t, err)
|
|
||||||
assert.Equal(t, total+1, n)
|
|
||||||
}
|
|
||||||
|
|
||||||
func addRepository(repository *models.RepoRecord) error {
|
|
||||||
return AddRepository(*repository)
|
|
||||||
}
|
|
||||||
|
|
||||||
func deleteRepository(name string) error {
|
|
||||||
return DeleteRepository(name)
|
|
||||||
}
|
|
||||||
|
|
||||||
func clearRepositoryData() error {
|
|
||||||
return ClearTable(models.RepoTable)
|
|
||||||
}
|
|
@ -1,34 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 dao
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
)
|
|
||||||
|
|
||||||
const (
|
|
||||||
// SchemaVersion is the version of database schema
|
|
||||||
SchemaVersion = "1.6.0"
|
|
||||||
)
|
|
||||||
|
|
||||||
// GetSchemaVersion return the version of database schema
|
|
||||||
func GetSchemaVersion() (*models.SchemaVersion, error) {
|
|
||||||
version := &models.SchemaVersion{}
|
|
||||||
if err := GetOrmer().Raw("select version_num from alembic_version").
|
|
||||||
QueryRow(version); err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return version, nil
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 dao
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
"github.com/stretchr/testify/require"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestGetSchemaVersion(t *testing.T) {
|
|
||||||
version, err := GetSchemaVersion()
|
|
||||||
require.Nil(t, err)
|
|
||||||
assert.Equal(t, SchemaVersion, version.Version)
|
|
||||||
}
|
|
@ -23,8 +23,6 @@ func init() {
|
|||||||
new(User),
|
new(User),
|
||||||
new(Project),
|
new(Project),
|
||||||
new(Role),
|
new(Role),
|
||||||
new(RepoRecord),
|
|
||||||
new(ProjectMetadata),
|
|
||||||
new(ResourceLabel),
|
new(ResourceLabel),
|
||||||
new(JobLog),
|
new(JobLog),
|
||||||
new(OIDCUser),
|
new(OIDCUser),
|
||||||
|
@ -14,10 +14,6 @@
|
|||||||
|
|
||||||
package models
|
package models
|
||||||
|
|
||||||
import (
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
// keys of project metadata and severity values
|
// keys of project metadata and severity values
|
||||||
const (
|
const (
|
||||||
ProMetaPublic = "public"
|
ProMetaPublic = "public"
|
||||||
@ -27,13 +23,3 @@ const (
|
|||||||
ProMetaAutoScan = "auto_scan"
|
ProMetaAutoScan = "auto_scan"
|
||||||
ProMetaReuseSysCVEAllowlist = "reuse_sys_cve_allowlist"
|
ProMetaReuseSysCVEAllowlist = "reuse_sys_cve_allowlist"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ProjectMetadata holds the metadata of a project.
|
|
||||||
type ProjectMetadata struct {
|
|
||||||
ID int64 `orm:"pk;auto;column(id)" json:"id"`
|
|
||||||
ProjectID int64 `orm:"column(project_id)" json:"project_id"`
|
|
||||||
Name string `orm:"column(name)" json:"name"`
|
|
||||||
Value string `orm:"column(value)" json:"value"`
|
|
||||||
CreationTime time.Time `orm:"column(creation_time);auto_now_add" json:"creation_time"`
|
|
||||||
UpdateTime time.Time `orm:"column(update_time);auto_now" json:"update_time"`
|
|
||||||
}
|
|
||||||
|
@ -1,20 +0,0 @@
|
|||||||
// Copyright Project Harbor Authors
|
|
||||||
//
|
|
||||||
// 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 models
|
|
||||||
|
|
||||||
// SchemaVersion is the version of database schema
|
|
||||||
type SchemaVersion struct {
|
|
||||||
Version string `json:"version" orm:"column(version_num)"`
|
|
||||||
}
|
|
@ -20,7 +20,6 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/controller/artifact/processor/chart"
|
"github.com/goharbor/harbor/src/controller/artifact/processor/chart"
|
||||||
"github.com/goharbor/harbor/src/controller/artifact/processor/cnab"
|
"github.com/goharbor/harbor/src/controller/artifact/processor/cnab"
|
||||||
"github.com/goharbor/harbor/src/controller/artifact/processor/image"
|
"github.com/goharbor/harbor/src/controller/artifact/processor/image"
|
||||||
@ -32,6 +31,7 @@ import (
|
|||||||
"github.com/goharbor/harbor/src/lib/q"
|
"github.com/goharbor/harbor/src/lib/q"
|
||||||
"github.com/goharbor/harbor/src/pkg/artifact"
|
"github.com/goharbor/harbor/src/pkg/artifact"
|
||||||
"github.com/goharbor/harbor/src/pkg/label/model"
|
"github.com/goharbor/harbor/src/pkg/label/model"
|
||||||
|
repomodel "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
model_tag "github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
model_tag "github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
||||||
tagtesting "github.com/goharbor/harbor/src/testing/controller/tag"
|
tagtesting "github.com/goharbor/harbor/src/testing/controller/tag"
|
||||||
ormtesting "github.com/goharbor/harbor/src/testing/lib/orm"
|
ormtesting "github.com/goharbor/harbor/src/testing/lib/orm"
|
||||||
@ -60,7 +60,7 @@ func (f *fakeAbstractor) AbstractMetadata(ctx context.Context, artifact *artifac
|
|||||||
type controllerTestSuite struct {
|
type controllerTestSuite struct {
|
||||||
suite.Suite
|
suite.Suite
|
||||||
ctl *controller
|
ctl *controller
|
||||||
repoMgr *repotesting.FakeManager
|
repoMgr *repotesting.Manager
|
||||||
artMgr *arttesting.FakeManager
|
artMgr *arttesting.FakeManager
|
||||||
artrashMgr *artrashtesting.FakeManager
|
artrashMgr *artrashtesting.FakeManager
|
||||||
blobMgr *blob.Manager
|
blobMgr *blob.Manager
|
||||||
@ -72,7 +72,7 @@ type controllerTestSuite struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) SetupTest() {
|
func (c *controllerTestSuite) SetupTest() {
|
||||||
c.repoMgr = &repotesting.FakeManager{}
|
c.repoMgr = &repotesting.Manager{}
|
||||||
c.artMgr = &arttesting.FakeManager{}
|
c.artMgr = &arttesting.FakeManager{}
|
||||||
c.artrashMgr = &artrashtesting.FakeManager{}
|
c.artrashMgr = &artrashtesting.FakeManager{}
|
||||||
c.blobMgr = &blob.Manager{}
|
c.blobMgr = &blob.Manager{}
|
||||||
@ -207,7 +207,7 @@ func (c *controllerTestSuite) TestEnsureArtifact() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
|
|
||||||
// the artifact doesn't exist
|
// the artifact doesn't exist
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.artMgr.On("GetByDigest").Return(nil, errors.NotFoundError(nil))
|
c.artMgr.On("GetByDigest").Return(nil, errors.NotFoundError(nil))
|
||||||
@ -223,7 +223,7 @@ func (c *controllerTestSuite) TestEnsure() {
|
|||||||
digest := "sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180"
|
digest := "sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180"
|
||||||
|
|
||||||
// both the artifact and the tag don't exist
|
// both the artifact and the tag don't exist
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.artMgr.On("GetByDigest").Return(nil, errors.NotFoundError(nil))
|
c.artMgr.On("GetByDigest").Return(nil, errors.NotFoundError(nil))
|
||||||
@ -267,10 +267,10 @@ func (c *controllerTestSuite) TestList() {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("List").Return([]*models.RepoRecord{
|
c.repoMgr.On("List", mock.Anything, mock.Anything).Return([]*repomodel.RepoRecord{
|
||||||
{RepositoryID: 1, Name: "library/hello-world"},
|
{RepositoryID: 1, Name: "library/hello-world"},
|
||||||
}, nil)
|
}, nil)
|
||||||
artifacts, err := c.ctl.List(nil, query, option)
|
artifacts, err := c.ctl.List(nil, query, option)
|
||||||
@ -286,7 +286,7 @@ func (c *controllerTestSuite) TestGet() {
|
|||||||
ID: 1,
|
ID: 1,
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
art, err := c.ctl.Get(nil, 1, nil)
|
art, err := c.ctl.Get(nil, 1, nil)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
c.Require().NotNil(art)
|
c.Require().NotNil(art)
|
||||||
@ -295,7 +295,7 @@ func (c *controllerTestSuite) TestGet() {
|
|||||||
|
|
||||||
func (c *controllerTestSuite) TestGetByDigest() {
|
func (c *controllerTestSuite) TestGetByDigest() {
|
||||||
// not found
|
// not found
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.artMgr.On("GetByDigest").Return(nil, errors.NotFoundError(nil))
|
c.artMgr.On("GetByDigest").Return(nil, errors.NotFoundError(nil))
|
||||||
@ -308,14 +308,14 @@ func (c *controllerTestSuite) TestGetByDigest() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
|
|
||||||
// success
|
// success
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.artMgr.On("GetByDigest").Return(&artifact.Artifact{
|
c.artMgr.On("GetByDigest").Return(&artifact.Artifact{
|
||||||
ID: 1,
|
ID: 1,
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
art, err = c.ctl.getByDigest(nil, "library/hello-world",
|
art, err = c.ctl.getByDigest(nil, "library/hello-world",
|
||||||
"sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180", nil)
|
"sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180", nil)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
@ -325,7 +325,7 @@ func (c *controllerTestSuite) TestGetByDigest() {
|
|||||||
|
|
||||||
func (c *controllerTestSuite) TestGetByTag() {
|
func (c *controllerTestSuite) TestGetByTag() {
|
||||||
// not found
|
// not found
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.tagCtl.On("List").Return(nil, nil)
|
c.tagCtl.On("List").Return(nil, nil)
|
||||||
@ -337,7 +337,7 @@ func (c *controllerTestSuite) TestGetByTag() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
|
|
||||||
// success
|
// success
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.tagCtl.On("List").Return([]*tag.Tag{
|
c.tagCtl.On("List").Return([]*tag.Tag{
|
||||||
@ -353,7 +353,7 @@ func (c *controllerTestSuite) TestGetByTag() {
|
|||||||
c.artMgr.On("Get").Return(&artifact.Artifact{
|
c.artMgr.On("Get").Return(&artifact.Artifact{
|
||||||
ID: 1,
|
ID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
art, err = c.ctl.getByTag(nil, "library/hello-world", "latest", nil)
|
art, err = c.ctl.getByTag(nil, "library/hello-world", "latest", nil)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
c.Require().NotNil(art)
|
c.Require().NotNil(art)
|
||||||
@ -362,14 +362,14 @@ func (c *controllerTestSuite) TestGetByTag() {
|
|||||||
|
|
||||||
func (c *controllerTestSuite) TestGetByReference() {
|
func (c *controllerTestSuite) TestGetByReference() {
|
||||||
// reference is digest
|
// reference is digest
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.artMgr.On("GetByDigest").Return(&artifact.Artifact{
|
c.artMgr.On("GetByDigest").Return(&artifact.Artifact{
|
||||||
ID: 1,
|
ID: 1,
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
art, err := c.ctl.GetByReference(nil, "library/hello-world",
|
art, err := c.ctl.GetByReference(nil, "library/hello-world",
|
||||||
"sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180", nil)
|
"sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180", nil)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
@ -380,7 +380,7 @@ func (c *controllerTestSuite) TestGetByReference() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
|
|
||||||
// reference is tag
|
// reference is tag
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.tagCtl.On("List").Return([]*tag.Tag{
|
c.tagCtl.On("List").Return([]*tag.Tag{
|
||||||
@ -396,7 +396,7 @@ func (c *controllerTestSuite) TestGetByReference() {
|
|||||||
c.artMgr.On("Get").Return(&artifact.Artifact{
|
c.artMgr.On("Get").Return(&artifact.Artifact{
|
||||||
ID: 1,
|
ID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
art, err = c.ctl.GetByReference(nil, "library/hello-world", "latest", nil)
|
art, err = c.ctl.GetByReference(nil, "library/hello-world", "latest", nil)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
c.Require().NotNil(art)
|
c.Require().NotNil(art)
|
||||||
@ -431,7 +431,7 @@ func (c *controllerTestSuite) TestDeleteDeeply() {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
c.artrashMgr.On("Create").Return(0, nil)
|
c.artrashMgr.On("Create").Return(0, nil)
|
||||||
err = c.ctl.deleteDeeply(orm.NewContext(nil, &ormtesting.FakeOrmer{}), 1, false)
|
err = c.ctl.deleteDeeply(orm.NewContext(nil, &ormtesting.FakeOrmer{}), 1, false)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
@ -442,7 +442,7 @@ func (c *controllerTestSuite) TestDeleteDeeply() {
|
|||||||
// root artifact is referenced by other artifacts
|
// root artifact is referenced by other artifacts
|
||||||
c.artMgr.On("Get").Return(&artifact.Artifact{ID: 1}, nil)
|
c.artMgr.On("Get").Return(&artifact.Artifact{ID: 1}, nil)
|
||||||
c.tagCtl.On("List").Return(nil, nil)
|
c.tagCtl.On("List").Return(nil, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
c.artMgr.On("ListReferences").Return([]*artifact.Reference{
|
c.artMgr.On("ListReferences").Return([]*artifact.Reference{
|
||||||
{
|
{
|
||||||
ID: 1,
|
ID: 1,
|
||||||
@ -457,7 +457,7 @@ func (c *controllerTestSuite) TestDeleteDeeply() {
|
|||||||
// child artifact contains no tag but referenced by other artifacts
|
// child artifact contains no tag but referenced by other artifacts
|
||||||
c.artMgr.On("Get").Return(&artifact.Artifact{ID: 1}, nil)
|
c.artMgr.On("Get").Return(&artifact.Artifact{ID: 1}, nil)
|
||||||
c.tagCtl.On("List").Return(nil, nil)
|
c.tagCtl.On("List").Return(nil, nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{}, nil)
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{}, nil)
|
||||||
c.artMgr.On("ListReferences").Return([]*artifact.Reference{
|
c.artMgr.On("ListReferences").Return([]*artifact.Reference{
|
||||||
{
|
{
|
||||||
ID: 1,
|
ID: 1,
|
||||||
@ -472,7 +472,7 @@ func (c *controllerTestSuite) TestCopy() {
|
|||||||
ID: 1,
|
ID: 1,
|
||||||
Digest: "sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180",
|
Digest: "sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180",
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
@ -487,7 +487,7 @@ func (c *controllerTestSuite) TestCopy() {
|
|||||||
},
|
},
|
||||||
}, nil)
|
}, nil)
|
||||||
c.tagCtl.On("Update").Return(nil)
|
c.tagCtl.On("Update").Return(nil)
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&repomodel.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
|
@ -17,7 +17,6 @@ package repository
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/common/utils"
|
"github.com/goharbor/harbor/src/common/utils"
|
||||||
"github.com/goharbor/harbor/src/controller/artifact"
|
"github.com/goharbor/harbor/src/controller/artifact"
|
||||||
"github.com/goharbor/harbor/src/lib/errors"
|
"github.com/goharbor/harbor/src/lib/errors"
|
||||||
@ -27,6 +26,7 @@ import (
|
|||||||
art "github.com/goharbor/harbor/src/pkg/artifact"
|
art "github.com/goharbor/harbor/src/pkg/artifact"
|
||||||
"github.com/goharbor/harbor/src/pkg/project"
|
"github.com/goharbor/harbor/src/pkg/project"
|
||||||
"github.com/goharbor/harbor/src/pkg/repository"
|
"github.com/goharbor/harbor/src/pkg/repository"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -43,15 +43,15 @@ type Controller interface {
|
|||||||
// Count returns the total count of repositories according to the query
|
// Count returns the total count of repositories according to the query
|
||||||
Count(ctx context.Context, query *q.Query) (total int64, err error)
|
Count(ctx context.Context, query *q.Query) (total int64, err error)
|
||||||
// List repositories according to the query
|
// List repositories according to the query
|
||||||
List(ctx context.Context, query *q.Query) (repositories []*models.RepoRecord, err error)
|
List(ctx context.Context, query *q.Query) (repositories []*model.RepoRecord, err error)
|
||||||
// Get the repository specified by ID
|
// Get the repository specified by ID
|
||||||
Get(ctx context.Context, id int64) (repository *models.RepoRecord, err error)
|
Get(ctx context.Context, id int64) (repository *model.RepoRecord, err error)
|
||||||
// GetByName gets the repository specified by name
|
// GetByName gets the repository specified by name
|
||||||
GetByName(ctx context.Context, name string) (repository *models.RepoRecord, err error)
|
GetByName(ctx context.Context, name string) (repository *model.RepoRecord, err error)
|
||||||
// Delete the repository specified by ID
|
// Delete the repository specified by ID
|
||||||
Delete(ctx context.Context, id int64) (err error)
|
Delete(ctx context.Context, id int64) (err error)
|
||||||
// Update the repository. Specify the properties or all properties will be updated
|
// Update the repository. Specify the properties or all properties will be updated
|
||||||
Update(ctx context.Context, repository *models.RepoRecord, properties ...string) (err error)
|
Update(ctx context.Context, repository *model.RepoRecord, properties ...string) (err error)
|
||||||
// AddPullCount increase one pull count for the specified repository
|
// AddPullCount increase one pull count for the specified repository
|
||||||
AddPullCount(ctx context.Context, id int64) error
|
AddPullCount(ctx context.Context, id int64) error
|
||||||
}
|
}
|
||||||
@ -99,7 +99,7 @@ func (c *controller) Ensure(ctx context.Context, name string) (bool, int64, erro
|
|||||||
// use orm.WithTransaction here to avoid the issue:
|
// use orm.WithTransaction here to avoid the issue:
|
||||||
// https://www.postgresql.org/message-id/002e01c04da9%24a8f95c20%2425efe6c1%40lasting.ro
|
// https://www.postgresql.org/message-id/002e01c04da9%24a8f95c20%2425efe6c1%40lasting.ro
|
||||||
if err = orm.WithTransaction(func(ctx context.Context) error {
|
if err = orm.WithTransaction(func(ctx context.Context) error {
|
||||||
id, err = c.repoMgr.Create(ctx, &models.RepoRecord{
|
id, err = c.repoMgr.Create(ctx, &model.RepoRecord{
|
||||||
ProjectID: project.ProjectID,
|
ProjectID: project.ProjectID,
|
||||||
Name: name,
|
Name: name,
|
||||||
})
|
})
|
||||||
@ -129,15 +129,15 @@ func (c *controller) Count(ctx context.Context, query *q.Query) (int64, error) {
|
|||||||
return c.repoMgr.Count(ctx, query)
|
return c.repoMgr.Count(ctx, query)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controller) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, error) {
|
func (c *controller) List(ctx context.Context, query *q.Query) ([]*model.RepoRecord, error) {
|
||||||
return c.repoMgr.List(ctx, query)
|
return c.repoMgr.List(ctx, query)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controller) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
func (c *controller) Get(ctx context.Context, id int64) (*model.RepoRecord, error) {
|
||||||
return c.repoMgr.Get(ctx, id)
|
return c.repoMgr.Get(ctx, id)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controller) GetByName(ctx context.Context, name string) (*models.RepoRecord, error) {
|
func (c *controller) GetByName(ctx context.Context, name string) (*model.RepoRecord, error) {
|
||||||
return c.repoMgr.GetByName(ctx, name)
|
return c.repoMgr.GetByName(ctx, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -179,7 +179,7 @@ func (c *controller) Delete(ctx context.Context, id int64) error {
|
|||||||
return c.repoMgr.Delete(ctx, id)
|
return c.repoMgr.Delete(ctx, id)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controller) Update(ctx context.Context, repository *models.RepoRecord, properties ...string) error {
|
func (c *controller) Update(ctx context.Context, repository *model.RepoRecord, properties ...string) error {
|
||||||
return c.repoMgr.Update(ctx, repository, properties...)
|
return c.repoMgr.Update(ctx, repository, properties...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ import (
|
|||||||
"github.com/goharbor/harbor/src/controller/artifact"
|
"github.com/goharbor/harbor/src/controller/artifact"
|
||||||
"github.com/goharbor/harbor/src/lib/errors"
|
"github.com/goharbor/harbor/src/lib/errors"
|
||||||
"github.com/goharbor/harbor/src/lib/orm"
|
"github.com/goharbor/harbor/src/lib/orm"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
artifacttesting "github.com/goharbor/harbor/src/testing/controller/artifact"
|
artifacttesting "github.com/goharbor/harbor/src/testing/controller/artifact"
|
||||||
ormtesting "github.com/goharbor/harbor/src/testing/lib/orm"
|
ormtesting "github.com/goharbor/harbor/src/testing/lib/orm"
|
||||||
"github.com/goharbor/harbor/src/testing/mock"
|
"github.com/goharbor/harbor/src/testing/mock"
|
||||||
@ -34,14 +35,14 @@ type controllerTestSuite struct {
|
|||||||
suite.Suite
|
suite.Suite
|
||||||
ctl *controller
|
ctl *controller
|
||||||
proMgr *project.Manager
|
proMgr *project.Manager
|
||||||
repoMgr *repository.FakeManager
|
repoMgr *repository.Manager
|
||||||
argMgr *arttesting.FakeManager
|
argMgr *arttesting.FakeManager
|
||||||
artCtl *artifacttesting.Controller
|
artCtl *artifacttesting.Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) SetupTest() {
|
func (c *controllerTestSuite) SetupTest() {
|
||||||
c.proMgr = &project.Manager{}
|
c.proMgr = &project.Manager{}
|
||||||
c.repoMgr = &repository.FakeManager{}
|
c.repoMgr = &repository.Manager{}
|
||||||
c.argMgr = &arttesting.FakeManager{}
|
c.argMgr = &arttesting.FakeManager{}
|
||||||
c.artCtl = &artifacttesting.Controller{}
|
c.artCtl = &artifacttesting.Controller{}
|
||||||
c.ctl = &controller{
|
c.ctl = &controller{
|
||||||
@ -54,7 +55,7 @@ func (c *controllerTestSuite) SetupTest() {
|
|||||||
|
|
||||||
func (c *controllerTestSuite) TestEnsure() {
|
func (c *controllerTestSuite) TestEnsure() {
|
||||||
// already exists
|
// already exists
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
@ -69,11 +70,11 @@ func (c *controllerTestSuite) TestEnsure() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
|
|
||||||
// doesn't exist
|
// doesn't exist
|
||||||
c.repoMgr.On("GetByName").Return(nil, errors.NotFoundError(nil))
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(nil, errors.NotFoundError(nil))
|
||||||
c.proMgr.On("Get", mock.AnythingOfType("*context.valueCtx"), "library").Return(&models.Project{
|
c.proMgr.On("Get", mock.AnythingOfType("*context.valueCtx"), "library").Return(&models.Project{
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
c.repoMgr.On("Create").Return(1, nil)
|
c.repoMgr.On("Create", mock.Anything, mock.Anything).Return(int64(1), nil)
|
||||||
created, id, err = c.ctl.Ensure(orm.NewContext(nil, &ormtesting.FakeOrmer{}), "library/hello-world")
|
created, id, err = c.ctl.Ensure(orm.NewContext(nil, &ormtesting.FakeOrmer{}), "library/hello-world")
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
c.repoMgr.AssertExpectations(c.T())
|
c.repoMgr.AssertExpectations(c.T())
|
||||||
@ -83,14 +84,14 @@ func (c *controllerTestSuite) TestEnsure() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) TestCount() {
|
func (c *controllerTestSuite) TestCount() {
|
||||||
c.repoMgr.On("Count").Return(1, nil)
|
c.repoMgr.On("Count", mock.Anything, mock.Anything).Return(int64(1), nil)
|
||||||
total, err := c.ctl.Count(nil, nil)
|
total, err := c.ctl.Count(nil, nil)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
c.Equal(int64(1), total)
|
c.Equal(int64(1), total)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) TestList() {
|
func (c *controllerTestSuite) TestList() {
|
||||||
c.repoMgr.On("List").Return([]*models.RepoRecord{
|
c.repoMgr.On("List", mock.Anything, mock.Anything).Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
},
|
},
|
||||||
@ -102,7 +103,7 @@ func (c *controllerTestSuite) TestList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) TestGet() {
|
func (c *controllerTestSuite) TestGet() {
|
||||||
c.repoMgr.On("Get").Return(&models.RepoRecord{
|
c.repoMgr.On("Get", mock.Anything, mock.Anything).Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
repository, err := c.ctl.Get(nil, 1)
|
repository, err := c.ctl.Get(nil, 1)
|
||||||
@ -112,7 +113,7 @@ func (c *controllerTestSuite) TestGet() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) TestGetByName() {
|
func (c *controllerTestSuite) TestGetByName() {
|
||||||
c.repoMgr.On("GetByName").Return(&models.RepoRecord{
|
c.repoMgr.On("GetByName", mock.Anything, mock.Anything).Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
}, nil)
|
}, nil)
|
||||||
repository, err := c.ctl.GetByName(nil, "library/hello-world")
|
repository, err := c.ctl.GetByName(nil, "library/hello-world")
|
||||||
@ -127,14 +128,14 @@ func (c *controllerTestSuite) TestDelete() {
|
|||||||
c.argMgr.On("ListReferences").Return(nil, nil)
|
c.argMgr.On("ListReferences").Return(nil, nil)
|
||||||
mock.OnAnything(c.artCtl, "List").Return([]*artifact.Artifact{art}, nil)
|
mock.OnAnything(c.artCtl, "List").Return([]*artifact.Artifact{art}, nil)
|
||||||
mock.OnAnything(c.artCtl, "Delete").Return(nil)
|
mock.OnAnything(c.artCtl, "Delete").Return(nil)
|
||||||
c.repoMgr.On("Delete").Return(nil)
|
c.repoMgr.On("Delete", mock.Anything, mock.Anything).Return(nil)
|
||||||
err := c.ctl.Delete(nil, 1)
|
err := c.ctl.Delete(nil, 1)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) TestUpdate() {
|
func (c *controllerTestSuite) TestUpdate() {
|
||||||
c.repoMgr.On("Update").Return(nil)
|
c.repoMgr.On("Update", mock.Anything, mock.Anything, mock.Anything).Return(nil)
|
||||||
err := c.ctl.Update(nil, &models.RepoRecord{
|
err := c.ctl.Update(nil, &model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Description: "description",
|
Description: "description",
|
||||||
}, "Description")
|
}, "Description")
|
||||||
@ -142,7 +143,7 @@ func (c *controllerTestSuite) TestUpdate() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) TestAddPullCount() {
|
func (c *controllerTestSuite) TestAddPullCount() {
|
||||||
c.repoMgr.On("AddPullCount").Return(nil)
|
c.repoMgr.On("AddPullCount", mock.Anything, mock.Anything).Return(nil)
|
||||||
err := c.ctl.AddPullCount(nil, 1)
|
err := c.ctl.AddPullCount(nil, 1)
|
||||||
c.Require().Nil(err)
|
c.Require().Nil(err)
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,7 @@ func TestController(t *testing.T) {
|
|||||||
|
|
||||||
func (s *ControllerTestSuite) TestPolicy() {
|
func (s *ControllerTestSuite) TestPolicy() {
|
||||||
projectMgr := &project.Manager{}
|
projectMgr := &project.Manager{}
|
||||||
repositoryMgr := &repository.FakeManager{}
|
repositoryMgr := &repository.Manager{}
|
||||||
retentionScheduler := &fakeRetentionScheduler{}
|
retentionScheduler := &fakeRetentionScheduler{}
|
||||||
retentionLauncher := &fakeLauncher{}
|
retentionLauncher := &fakeLauncher{}
|
||||||
execMgr := &testingTask.ExecutionManager{}
|
execMgr := &testingTask.ExecutionManager{}
|
||||||
@ -196,7 +196,7 @@ func (s *ControllerTestSuite) TestPolicy() {
|
|||||||
|
|
||||||
func (s *ControllerTestSuite) TestExecution() {
|
func (s *ControllerTestSuite) TestExecution() {
|
||||||
projectMgr := &project.Manager{}
|
projectMgr := &project.Manager{}
|
||||||
repositoryMgr := &repository.FakeManager{}
|
repositoryMgr := &repository.Manager{}
|
||||||
retentionScheduler := &fakeRetentionScheduler{}
|
retentionScheduler := &fakeRetentionScheduler{}
|
||||||
retentionLauncher := &fakeLauncher{}
|
retentionLauncher := &fakeLauncher{}
|
||||||
execMgr := &testingTask.ExecutionManager{}
|
execMgr := &testingTask.ExecutionManager{}
|
||||||
|
@ -35,14 +35,14 @@ import (
|
|||||||
type controllerTestSuite struct {
|
type controllerTestSuite struct {
|
||||||
suite.Suite
|
suite.Suite
|
||||||
ctl *controller
|
ctl *controller
|
||||||
repoMgr *repository.FakeManager
|
repoMgr *repository.Manager
|
||||||
artMgr *artifact.FakeManager
|
artMgr *artifact.FakeManager
|
||||||
tagMgr *tagtesting.FakeManager
|
tagMgr *tagtesting.FakeManager
|
||||||
immutableMtr *immutable.FakeMatcher
|
immutableMtr *immutable.FakeMatcher
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *controllerTestSuite) SetupTest() {
|
func (c *controllerTestSuite) SetupTest() {
|
||||||
c.repoMgr = &repository.FakeManager{}
|
c.repoMgr = &repository.Manager{}
|
||||||
c.artMgr = &artifact.FakeManager{}
|
c.artMgr = &artifact.FakeManager{}
|
||||||
c.tagMgr = &tagtesting.FakeManager{}
|
c.tagMgr = &tagtesting.FakeManager{}
|
||||||
c.immutableMtr = &immutable.FakeMatcher{}
|
c.immutableMtr = &immutable.FakeMatcher{}
|
||||||
|
@ -19,6 +19,7 @@ import (
|
|||||||
memberModels "github.com/goharbor/harbor/src/pkg/member/models"
|
memberModels "github.com/goharbor/harbor/src/pkg/member/models"
|
||||||
qtypes "github.com/goharbor/harbor/src/pkg/quota/types"
|
qtypes "github.com/goharbor/harbor/src/pkg/quota/types"
|
||||||
"github.com/goharbor/harbor/src/pkg/repository"
|
"github.com/goharbor/harbor/src/pkg/repository"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/pkg/user"
|
"github.com/goharbor/harbor/src/pkg/user"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -30,8 +31,8 @@ var (
|
|||||||
testPro2 = models.Project{OwnerID: 1, Name: "test2", Metadata: map[string]string{"public": "false"}}
|
testPro2 = models.Project{OwnerID: 1, Name: "test2", Metadata: map[string]string{"public": "false"}}
|
||||||
rs1 = qtypes.ResourceList{qtypes.ResourceStorage: 100}
|
rs1 = qtypes.ResourceList{qtypes.ResourceStorage: 100}
|
||||||
rs2 = qtypes.ResourceList{qtypes.ResourceStorage: 200}
|
rs2 = qtypes.ResourceList{qtypes.ResourceStorage: 200}
|
||||||
repo1 = models.RepoRecord{Name: "repo1"}
|
repo1 = model.RepoRecord{Name: "repo1"}
|
||||||
repo2 = models.RepoRecord{Name: "repo2"}
|
repo2 = model.RepoRecord{Name: "repo2"}
|
||||||
pmIDs = []int{}
|
pmIDs = []int{}
|
||||||
art1 = artifact.Artifact{RepositoryName: repo1.Name, Type: "IMAGE", Digest: "sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180"}
|
art1 = artifact.Artifact{RepositoryName: repo1.Name, Type: "IMAGE", Digest: "sha256:418fb88ec412e340cdbef913b8ca1bbe8f9e8dc705f9617414c1f2c8db980180"}
|
||||||
art2 = artifact.Artifact{RepositoryName: repo1.Name, Type: "IMAGE", Digest: "sha256:3198b18471892718923712837192831287312893712893712897312db1a3bc73"}
|
art2 = artifact.Artifact{RepositoryName: repo1.Name, Type: "IMAGE", Digest: "sha256:3198b18471892718923712837192831287312893712893712897312db1a3bc73"}
|
||||||
|
@ -15,8 +15,20 @@
|
|||||||
package models
|
package models
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
"github.com/astaxie/beego/orm"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ProjectMetadata ...
|
func init() {
|
||||||
type ProjectMetadata = models.ProjectMetadata
|
orm.RegisterModel(new(ProjectMetadata))
|
||||||
|
}
|
||||||
|
|
||||||
|
// ProjectMetadata holds the metadata of a project.
|
||||||
|
type ProjectMetadata struct {
|
||||||
|
ID int64 `orm:"pk;auto;column(id)" json:"id"`
|
||||||
|
ProjectID int64 `orm:"column(project_id)" json:"project_id"`
|
||||||
|
Name string `orm:"column(name)" json:"name"`
|
||||||
|
Value string `orm:"column(value)" json:"value"`
|
||||||
|
CreationTime time.Time `orm:"column(creation_time);auto_now_add" json:"creation_time"`
|
||||||
|
UpdateTime time.Time `orm:"column(update_time);auto_now" json:"update_time"`
|
||||||
|
}
|
||||||
|
@ -17,9 +17,9 @@ package v1
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/pkg/reg/adapter/harbor/base"
|
"github.com/goharbor/harbor/src/pkg/reg/adapter/harbor/base"
|
||||||
"github.com/goharbor/harbor/src/pkg/reg/model"
|
"github.com/goharbor/harbor/src/pkg/reg/model"
|
||||||
|
repomodel "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
type client struct {
|
type client struct {
|
||||||
@ -27,7 +27,7 @@ type client struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) listRepositories(project *base.Project) ([]*model.Repository, error) {
|
func (c *client) listRepositories(project *base.Project) ([]*model.Repository, error) {
|
||||||
repositories := []*models.RepoRecord{}
|
repositories := []*repomodel.RepoRecord{}
|
||||||
url := fmt.Sprintf("%s/repositories?project_id=%d", c.BasePath(), project.ID)
|
url := fmt.Sprintf("%s/repositories?project_id=%d", c.BasePath(), project.ID)
|
||||||
if err := c.C.GetAndIteratePagination(url, &repositories); err != nil {
|
if err := c.C.GetAndIteratePagination(url, &repositories); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -16,12 +16,13 @@ package v2
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/common/utils"
|
"github.com/goharbor/harbor/src/common/utils"
|
||||||
"github.com/goharbor/harbor/src/controller/artifact"
|
"github.com/goharbor/harbor/src/controller/artifact"
|
||||||
"github.com/goharbor/harbor/src/lib/encode/repository"
|
"github.com/goharbor/harbor/src/lib/encode/repository"
|
||||||
"github.com/goharbor/harbor/src/pkg/reg/adapter/harbor/base"
|
"github.com/goharbor/harbor/src/pkg/reg/adapter/harbor/base"
|
||||||
"github.com/goharbor/harbor/src/pkg/reg/model"
|
"github.com/goharbor/harbor/src/pkg/reg/model"
|
||||||
|
repomodel "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
type client struct {
|
type client struct {
|
||||||
@ -29,7 +30,7 @@ type client struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) listRepositories(project *base.Project) ([]*model.Repository, error) {
|
func (c *client) listRepositories(project *base.Project) ([]*model.Repository, error) {
|
||||||
repositories := []*models.RepoRecord{}
|
repositories := []*repomodel.RepoRecord{}
|
||||||
url := fmt.Sprintf("%s/projects/%s/repositories", c.BasePath(), project.Name)
|
url := fmt.Sprintf("%s/projects/%s/repositories", c.BasePath(), project.Name)
|
||||||
if err := c.C.GetAndIteratePagination(url, &repositories); err != nil {
|
if err := c.C.GetAndIteratePagination(url, &repositories); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -79,7 +80,7 @@ func (c *client) deleteTag(repo, tag string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) getRepositoryByBlobDigest(digest string) (string, error) {
|
func (c *client) getRepositoryByBlobDigest(digest string) (string, error) {
|
||||||
repositories := []*models.RepoRecord{}
|
repositories := []*repomodel.RepoRecord{}
|
||||||
url := fmt.Sprintf("%s/repositories?q=blob_digest=%s&page_size=1&page_number=1", c.BasePath(), digest)
|
url := fmt.Sprintf("%s/repositories?q=blob_digest=%s&page_size=1&page_number=1", c.BasePath(), digest)
|
||||||
if err := c.C.Get(url, &repositories); err != nil {
|
if err := c.C.Get(url, &repositories); err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
|
@ -20,10 +20,10 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
o "github.com/astaxie/beego/orm"
|
o "github.com/astaxie/beego/orm"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/lib/errors"
|
"github.com/goharbor/harbor/src/lib/errors"
|
||||||
"github.com/goharbor/harbor/src/lib/orm"
|
"github.com/goharbor/harbor/src/lib/orm"
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
"github.com/goharbor/harbor/src/lib/q"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
// DAO is the data access object interface for repository
|
// DAO is the data access object interface for repository
|
||||||
@ -31,19 +31,19 @@ type DAO interface {
|
|||||||
// Count returns the total count of repositories according to the query
|
// Count returns the total count of repositories according to the query
|
||||||
Count(ctx context.Context, query *q.Query) (count int64, err error)
|
Count(ctx context.Context, query *q.Query) (count int64, err error)
|
||||||
// List repositories according to the query
|
// List repositories according to the query
|
||||||
List(ctx context.Context, query *q.Query) (repositories []*models.RepoRecord, err error)
|
List(ctx context.Context, query *q.Query) (repositories []*model.RepoRecord, err error)
|
||||||
// Get the repository specified by ID
|
// Get the repository specified by ID
|
||||||
Get(ctx context.Context, id int64) (repository *models.RepoRecord, err error)
|
Get(ctx context.Context, id int64) (repository *model.RepoRecord, err error)
|
||||||
// Create the repository
|
// Create the repository
|
||||||
Create(ctx context.Context, repository *models.RepoRecord) (id int64, err error)
|
Create(ctx context.Context, repository *model.RepoRecord) (id int64, err error)
|
||||||
// Delete the repository specified by ID
|
// Delete the repository specified by ID
|
||||||
Delete(ctx context.Context, id int64) (err error)
|
Delete(ctx context.Context, id int64) (err error)
|
||||||
// Update updates the repository. Only the properties specified by "props" will be updated if it is set
|
// Update updates the repository. Only the properties specified by "props" will be updated if it is set
|
||||||
Update(ctx context.Context, repository *models.RepoRecord, props ...string) (err error)
|
Update(ctx context.Context, repository *model.RepoRecord, props ...string) (err error)
|
||||||
// AddPullCount increase one pull count for the specified repository
|
// AddPullCount increase one pull count for the specified repository
|
||||||
AddPullCount(ctx context.Context, id int64) error
|
AddPullCount(ctx context.Context, id int64) error
|
||||||
// NonEmptyRepos returns the repositories without any artifact or all the artifacts are untagged.
|
// NonEmptyRepos returns the repositories without any artifact or all the artifacts are untagged.
|
||||||
NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error)
|
NonEmptyRepos(ctx context.Context) ([]*model.RepoRecord, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
// New returns an instance of the default DAO
|
// New returns an instance of the default DAO
|
||||||
@ -54,15 +54,15 @@ func New() DAO {
|
|||||||
type dao struct{}
|
type dao struct{}
|
||||||
|
|
||||||
func (d *dao) Count(ctx context.Context, query *q.Query) (int64, error) {
|
func (d *dao) Count(ctx context.Context, query *q.Query) (int64, error) {
|
||||||
qs, err := orm.QuerySetterForCount(ctx, &models.RepoRecord{}, query)
|
qs, err := orm.QuerySetterForCount(ctx, &model.RepoRecord{}, query)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
return qs.Count()
|
return qs.Count()
|
||||||
}
|
}
|
||||||
func (d *dao) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, error) {
|
func (d *dao) List(ctx context.Context, query *q.Query) ([]*model.RepoRecord, error) {
|
||||||
repositories := []*models.RepoRecord{}
|
repositories := []*model.RepoRecord{}
|
||||||
qs, err := orm.QuerySetter(ctx, &models.RepoRecord{}, query)
|
qs, err := orm.QuerySetter(ctx, &model.RepoRecord{}, query)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -72,8 +72,8 @@ func (d *dao) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, e
|
|||||||
return repositories, nil
|
return repositories, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *dao) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
func (d *dao) Get(ctx context.Context, id int64) (*model.RepoRecord, error) {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
RepositoryID: id,
|
RepositoryID: id,
|
||||||
}
|
}
|
||||||
ormer, err := orm.FromContext(ctx)
|
ormer, err := orm.FromContext(ctx)
|
||||||
@ -89,7 +89,7 @@ func (d *dao) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
|||||||
return repository, nil
|
return repository, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *dao) Create(ctx context.Context, repository *models.RepoRecord) (int64, error) {
|
func (d *dao) Create(ctx context.Context, repository *model.RepoRecord) (int64, error) {
|
||||||
ormer, err := orm.FromContext(ctx)
|
ormer, err := orm.FromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
@ -106,7 +106,7 @@ func (d *dao) Delete(ctx context.Context, id int64) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
n, err := ormer.Delete(&models.RepoRecord{
|
n, err := ormer.Delete(&model.RepoRecord{
|
||||||
RepositoryID: id,
|
RepositoryID: id,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -118,7 +118,7 @@ func (d *dao) Delete(ctx context.Context, id int64) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *dao) Update(ctx context.Context, repository *models.RepoRecord, props ...string) error {
|
func (d *dao) Update(ctx context.Context, repository *model.RepoRecord, props ...string) error {
|
||||||
ormer, err := orm.FromContext(ctx)
|
ormer, err := orm.FromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -138,7 +138,7 @@ func (d *dao) AddPullCount(ctx context.Context, id int64) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
num, err := ormer.QueryTable(new(models.RepoRecord)).Filter("RepositoryID", id).Update(
|
num, err := ormer.QueryTable(new(model.RepoRecord)).Filter("RepositoryID", id).Update(
|
||||||
o.Params{
|
o.Params{
|
||||||
"pull_count": o.ColValue(o.ColAdd, 1),
|
"pull_count": o.ColValue(o.ColAdd, 1),
|
||||||
"update_time": time.Now(),
|
"update_time": time.Now(),
|
||||||
@ -153,8 +153,8 @@ func (d *dao) AddPullCount(ctx context.Context, id int64) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *dao) NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error) {
|
func (d *dao) NonEmptyRepos(ctx context.Context) ([]*model.RepoRecord, error) {
|
||||||
var repos []*models.RepoRecord
|
var repos []*model.RepoRecord
|
||||||
ormer, err := orm.FromContext(ctx)
|
ormer, err := orm.FromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -19,11 +19,11 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
beegoorm "github.com/astaxie/beego/orm"
|
beegoorm "github.com/astaxie/beego/orm"
|
||||||
common_dao "github.com/goharbor/harbor/src/common/dao"
|
common_dao "github.com/goharbor/harbor/src/common/dao"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/lib/errors"
|
"github.com/goharbor/harbor/src/lib/errors"
|
||||||
"github.com/goharbor/harbor/src/lib/orm"
|
"github.com/goharbor/harbor/src/lib/orm"
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
"github.com/goharbor/harbor/src/lib/q"
|
||||||
af_dao "github.com/goharbor/harbor/src/pkg/artifact/dao"
|
af_dao "github.com/goharbor/harbor/src/pkg/artifact/dao"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
tag_dao "github.com/goharbor/harbor/src/pkg/tag/dao"
|
tag_dao "github.com/goharbor/harbor/src/pkg/tag/dao"
|
||||||
"github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
"github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
||||||
v1 "github.com/opencontainers/image-spec/specs-go/v1"
|
v1 "github.com/opencontainers/image-spec/specs-go/v1"
|
||||||
@ -54,7 +54,7 @@ func (d *daoTestSuite) SetupSuite() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (d *daoTestSuite) SetupTest() {
|
func (d *daoTestSuite) SetupTest() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
Name: repository,
|
Name: repository,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Description: "",
|
Description: "",
|
||||||
@ -126,7 +126,7 @@ func (d *daoTestSuite) TestCreate() {
|
|||||||
// the happy pass case is covered in Setup
|
// the happy pass case is covered in Setup
|
||||||
|
|
||||||
// conflict
|
// conflict
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
Name: repository,
|
Name: repository,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
}
|
}
|
||||||
@ -148,7 +148,7 @@ func (d *daoTestSuite) TestDelete() {
|
|||||||
|
|
||||||
func (d *daoTestSuite) TestUpdate() {
|
func (d *daoTestSuite) TestUpdate() {
|
||||||
// pass
|
// pass
|
||||||
err := d.dao.Update(d.ctx, &models.RepoRecord{
|
err := d.dao.Update(d.ctx, &model.RepoRecord{
|
||||||
RepositoryID: d.id,
|
RepositoryID: d.id,
|
||||||
PullCount: 1,
|
PullCount: 1,
|
||||||
}, "PullCount")
|
}, "PullCount")
|
||||||
@ -160,7 +160,7 @@ func (d *daoTestSuite) TestUpdate() {
|
|||||||
d.Equal(int64(1), repository.PullCount)
|
d.Equal(int64(1), repository.PullCount)
|
||||||
|
|
||||||
// not exist
|
// not exist
|
||||||
err = d.dao.Update(d.ctx, &models.RepoRecord{
|
err = d.dao.Update(d.ctx, &model.RepoRecord{
|
||||||
RepositoryID: 10000,
|
RepositoryID: 10000,
|
||||||
})
|
})
|
||||||
d.Require().NotNil(err)
|
d.Require().NotNil(err)
|
||||||
@ -170,7 +170,7 @@ func (d *daoTestSuite) TestUpdate() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (d *daoTestSuite) TestAddPullCount() {
|
func (d *daoTestSuite) TestAddPullCount() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
Name: "test/pullcount",
|
Name: "test/pullcount",
|
||||||
ProjectID: 10,
|
ProjectID: 10,
|
||||||
Description: "test pull count",
|
Description: "test pull count",
|
||||||
@ -191,7 +191,7 @@ func (d *daoTestSuite) TestAddPullCount() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (d *daoTestSuite) TestNonEmptyRepos() {
|
func (d *daoTestSuite) TestNonEmptyRepos() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
Name: "TestNonEmptyRepos",
|
Name: "TestNonEmptyRepos",
|
||||||
ProjectID: 10,
|
ProjectID: 10,
|
||||||
Description: "test pull count",
|
Description: "test pull count",
|
||||||
|
@ -16,10 +16,11 @@ package repository
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/lib/errors"
|
"github.com/goharbor/harbor/src/lib/errors"
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
"github.com/goharbor/harbor/src/lib/q"
|
||||||
"github.com/goharbor/harbor/src/pkg/repository/dao"
|
"github.com/goharbor/harbor/src/pkg/repository/dao"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Mgr is the global repository manager instance
|
// Mgr is the global repository manager instance
|
||||||
@ -30,21 +31,21 @@ type Manager interface {
|
|||||||
// Count returns the total count of repositories according to the query
|
// Count returns the total count of repositories according to the query
|
||||||
Count(ctx context.Context, query *q.Query) (total int64, err error)
|
Count(ctx context.Context, query *q.Query) (total int64, err error)
|
||||||
// List repositories according to the query
|
// List repositories according to the query
|
||||||
List(ctx context.Context, query *q.Query) (repositories []*models.RepoRecord, err error)
|
List(ctx context.Context, query *q.Query) (repositories []*model.RepoRecord, err error)
|
||||||
// Get the repository specified by ID
|
// Get the repository specified by ID
|
||||||
Get(ctx context.Context, id int64) (repository *models.RepoRecord, err error)
|
Get(ctx context.Context, id int64) (repository *model.RepoRecord, err error)
|
||||||
// GetByName gets the repository specified by name
|
// GetByName gets the repository specified by name
|
||||||
GetByName(ctx context.Context, name string) (repository *models.RepoRecord, err error)
|
GetByName(ctx context.Context, name string) (repository *model.RepoRecord, err error)
|
||||||
// Create a repository
|
// Create a repository
|
||||||
Create(ctx context.Context, repository *models.RepoRecord) (id int64, err error)
|
Create(ctx context.Context, repository *model.RepoRecord) (id int64, err error)
|
||||||
// Delete the repository specified by ID
|
// Delete the repository specified by ID
|
||||||
Delete(ctx context.Context, id int64) (err error)
|
Delete(ctx context.Context, id int64) (err error)
|
||||||
// Update updates the repository. Only the properties specified by "props" will be updated if it is set
|
// Update updates the repository. Only the properties specified by "props" will be updated if it is set
|
||||||
Update(ctx context.Context, repository *models.RepoRecord, props ...string) (err error)
|
Update(ctx context.Context, repository *model.RepoRecord, props ...string) (err error)
|
||||||
// AddPullCount increase one pull count for the specified repository
|
// AddPullCount increase one pull count for the specified repository
|
||||||
AddPullCount(ctx context.Context, id int64) error
|
AddPullCount(ctx context.Context, id int64) error
|
||||||
// NonEmptyRepos returns the repositories without any artifact or all the artifacts are untagged.
|
// NonEmptyRepos returns the repositories without any artifact or all the artifacts are untagged.
|
||||||
NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error)
|
NonEmptyRepos(ctx context.Context) ([]*model.RepoRecord, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
// New returns a default implementation of Manager
|
// New returns a default implementation of Manager
|
||||||
@ -62,7 +63,7 @@ func (m *manager) Count(ctx context.Context, query *q.Query) (int64, error) {
|
|||||||
return m.dao.Count(ctx, query)
|
return m.dao.Count(ctx, query)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *manager) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, error) {
|
func (m *manager) List(ctx context.Context, query *q.Query) ([]*model.RepoRecord, error) {
|
||||||
repositories, err := m.dao.List(ctx, query)
|
repositories, err := m.dao.List(ctx, query)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -70,11 +71,11 @@ func (m *manager) List(ctx context.Context, query *q.Query) ([]*models.RepoRecor
|
|||||||
return repositories, nil
|
return repositories, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *manager) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
func (m *manager) Get(ctx context.Context, id int64) (*model.RepoRecord, error) {
|
||||||
return m.dao.Get(ctx, id)
|
return m.dao.Get(ctx, id)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *manager) GetByName(ctx context.Context, name string) (repository *models.RepoRecord, err error) {
|
func (m *manager) GetByName(ctx context.Context, name string) (repository *model.RepoRecord, err error) {
|
||||||
repositories, err := m.List(ctx, &q.Query{
|
repositories, err := m.List(ctx, &q.Query{
|
||||||
Keywords: map[string]interface{}{
|
Keywords: map[string]interface{}{
|
||||||
"Name": name,
|
"Name": name,
|
||||||
@ -90,14 +91,14 @@ func (m *manager) GetByName(ctx context.Context, name string) (repository *model
|
|||||||
return repositories[0], nil
|
return repositories[0], nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *manager) Create(ctx context.Context, repository *models.RepoRecord) (int64, error) {
|
func (m *manager) Create(ctx context.Context, repository *model.RepoRecord) (int64, error) {
|
||||||
return m.dao.Create(ctx, repository)
|
return m.dao.Create(ctx, repository)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *manager) Delete(ctx context.Context, id int64) error {
|
func (m *manager) Delete(ctx context.Context, id int64) error {
|
||||||
return m.dao.Delete(ctx, id)
|
return m.dao.Delete(ctx, id)
|
||||||
}
|
}
|
||||||
func (m *manager) Update(ctx context.Context, repository *models.RepoRecord, props ...string) error {
|
func (m *manager) Update(ctx context.Context, repository *model.RepoRecord, props ...string) error {
|
||||||
return m.dao.Update(ctx, repository, props...)
|
return m.dao.Update(ctx, repository, props...)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -105,6 +106,6 @@ func (m *manager) AddPullCount(ctx context.Context, id int64) error {
|
|||||||
return m.dao.AddPullCount(ctx, id)
|
return m.dao.AddPullCount(ctx, id)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *manager) NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error) {
|
func (m *manager) NonEmptyRepos(ctx context.Context) ([]*model.RepoRecord, error) {
|
||||||
return m.dao.NonEmptyRepos(ctx)
|
return m.dao.NonEmptyRepos(ctx)
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/testing/pkg/repository/dao"
|
"github.com/goharbor/harbor/src/testing/pkg/repository/dao"
|
||||||
"github.com/stretchr/testify/mock"
|
"github.com/stretchr/testify/mock"
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
@ -46,12 +46,12 @@ func (m *managerTestSuite) TestCount() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *managerTestSuite) TestList() {
|
func (m *managerTestSuite) TestList() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}
|
}
|
||||||
m.dao.On("List", mock.Anything, mock.Anything).Return([]*models.RepoRecord{repository}, nil)
|
m.dao.On("List", mock.Anything, mock.Anything).Return([]*model.RepoRecord{repository}, nil)
|
||||||
rpers, err := m.mgr.List(context.Background(), nil)
|
rpers, err := m.mgr.List(context.Background(), nil)
|
||||||
m.Nil(err)
|
m.Nil(err)
|
||||||
m.Equal(1, len(rpers))
|
m.Equal(1, len(rpers))
|
||||||
@ -59,7 +59,7 @@ func (m *managerTestSuite) TestList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *managerTestSuite) TestGet() {
|
func (m *managerTestSuite) TestGet() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
@ -73,12 +73,12 @@ func (m *managerTestSuite) TestGet() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *managerTestSuite) TestGetByName() {
|
func (m *managerTestSuite) TestGetByName() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}
|
}
|
||||||
m.dao.On("List", mock.Anything, mock.Anything).Return([]*models.RepoRecord{repository}, nil)
|
m.dao.On("List", mock.Anything, mock.Anything).Return([]*model.RepoRecord{repository}, nil)
|
||||||
repo, err := m.mgr.GetByName(context.Background(), "library/hello-world")
|
repo, err := m.mgr.GetByName(context.Background(), "library/hello-world")
|
||||||
m.Require().Nil(err)
|
m.Require().Nil(err)
|
||||||
m.dao.AssertExpectations(m.T())
|
m.dao.AssertExpectations(m.T())
|
||||||
@ -88,7 +88,7 @@ func (m *managerTestSuite) TestGetByName() {
|
|||||||
|
|
||||||
func (m *managerTestSuite) TestCreate() {
|
func (m *managerTestSuite) TestCreate() {
|
||||||
m.dao.On("Create", mock.Anything, mock.Anything).Return(int64(1), nil)
|
m.dao.On("Create", mock.Anything, mock.Anything).Return(int64(1), nil)
|
||||||
_, err := m.mgr.Create(context.Background(), &models.RepoRecord{})
|
_, err := m.mgr.Create(context.Background(), &model.RepoRecord{})
|
||||||
m.Nil(err)
|
m.Nil(err)
|
||||||
m.dao.AssertExpectations(m.T())
|
m.dao.AssertExpectations(m.T())
|
||||||
}
|
}
|
||||||
@ -102,7 +102,7 @@ func (m *managerTestSuite) TestDelete() {
|
|||||||
|
|
||||||
func (m *managerTestSuite) TestUpdate() {
|
func (m *managerTestSuite) TestUpdate() {
|
||||||
m.dao.On("Update", mock.Anything, mock.Anything).Return(nil)
|
m.dao.On("Update", mock.Anything, mock.Anything).Return(nil)
|
||||||
err := m.mgr.Update(context.Background(), &models.RepoRecord{})
|
err := m.mgr.Update(context.Background(), &model.RepoRecord{})
|
||||||
m.Nil(err)
|
m.Nil(err)
|
||||||
m.dao.AssertExpectations(m.T())
|
m.dao.AssertExpectations(m.T())
|
||||||
}
|
}
|
||||||
@ -115,12 +115,12 @@ func (m *managerTestSuite) TestAddPullCount() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *managerTestSuite) TestNonEmptyRepos() {
|
func (m *managerTestSuite) TestNonEmptyRepos() {
|
||||||
repository := &models.RepoRecord{
|
repository := &model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}
|
}
|
||||||
m.dao.On("NonEmptyRepos", mock.Anything).Return([]*models.RepoRecord{repository}, nil)
|
m.dao.On("NonEmptyRepos", mock.Anything).Return([]*model.RepoRecord{repository}, nil)
|
||||||
repo, err := m.mgr.NonEmptyRepos(nil)
|
repo, err := m.mgr.NonEmptyRepos(nil)
|
||||||
m.Require().Nil(err)
|
m.Require().Nil(err)
|
||||||
m.dao.AssertExpectations(m.T())
|
m.dao.AssertExpectations(m.T())
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
package models
|
package model
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
@ -22,13 +22,13 @@ import (
|
|||||||
"github.com/astaxie/beego/orm"
|
"github.com/astaxie/beego/orm"
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
"github.com/goharbor/harbor/src/lib/q"
|
||||||
"github.com/lib/pq"
|
"github.com/lib/pq"
|
||||||
"github.com/theupdateframework/notary/tuf/data"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// RepoTable is the table name for repository
|
func init() {
|
||||||
const RepoTable = "repository"
|
orm.RegisterModel(
|
||||||
|
new(RepoRecord),
|
||||||
// TODO move the model into pkg/repository
|
)
|
||||||
|
}
|
||||||
|
|
||||||
// RepoRecord holds the record of an repository in DB, all the infors are from the registry notification event.
|
// RepoRecord holds the record of an repository in DB, all the infors are from the registry notification event.
|
||||||
type RepoRecord struct {
|
type RepoRecord struct {
|
||||||
@ -59,7 +59,7 @@ func (r *RepoRecord) FilterByBlobDigest(ctx context.Context, qs orm.QuerySeter,
|
|||||||
|
|
||||||
// TableName is required by by beego orm to map RepoRecord to table repository
|
// TableName is required by by beego orm to map RepoRecord to table repository
|
||||||
func (r *RepoRecord) TableName() string {
|
func (r *RepoRecord) TableName() string {
|
||||||
return RepoTable
|
return "repository"
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetDefaultSorts specifies the default sorts
|
// GetDefaultSorts specifies the default sorts
|
||||||
@ -75,39 +75,3 @@ func (r *RepoRecord) GetDefaultSorts() []*q.Sort {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// RepositoryQuery : query parameters for repository
|
|
||||||
type RepositoryQuery struct {
|
|
||||||
Name string
|
|
||||||
ProjectIDs []int64
|
|
||||||
ProjectName string
|
|
||||||
LabelID int64
|
|
||||||
Pagination
|
|
||||||
Sorting
|
|
||||||
}
|
|
||||||
|
|
||||||
// TagDetail ...
|
|
||||||
type TagDetail struct {
|
|
||||||
Digest string `json:"digest"`
|
|
||||||
Name string `json:"name"`
|
|
||||||
Size int64 `json:"size"`
|
|
||||||
Architecture string `json:"architecture"`
|
|
||||||
OS string `json:"os"`
|
|
||||||
OSVersion string `json:"os.version"`
|
|
||||||
DockerVersion string `json:"docker_version"`
|
|
||||||
Author string `json:"author"`
|
|
||||||
Created time.Time `json:"created"`
|
|
||||||
Config *TagCfg `json:"config"`
|
|
||||||
Immutable bool `json:"immutable"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// TagCfg ...
|
|
||||||
type TagCfg struct {
|
|
||||||
Labels map[string]string `json:"labels"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// Signature ...
|
|
||||||
type Signature struct {
|
|
||||||
Tag string `json:"tag"`
|
|
||||||
Hashes data.Hashes `json:"hashes"`
|
|
||||||
}
|
|
@ -23,6 +23,7 @@ import (
|
|||||||
"github.com/goharbor/harbor/src/common/models"
|
"github.com/goharbor/harbor/src/common/models"
|
||||||
_ "github.com/goharbor/harbor/src/lib/selector/selectors/doublestar"
|
_ "github.com/goharbor/harbor/src/lib/selector/selectors/doublestar"
|
||||||
"github.com/goharbor/harbor/src/pkg/project"
|
"github.com/goharbor/harbor/src/pkg/project"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/pkg/retention/policy"
|
"github.com/goharbor/harbor/src/pkg/retention/policy"
|
||||||
"github.com/goharbor/harbor/src/pkg/retention/policy/rule"
|
"github.com/goharbor/harbor/src/pkg/retention/policy/rule"
|
||||||
"github.com/goharbor/harbor/src/pkg/retention/q"
|
"github.com/goharbor/harbor/src/pkg/retention/q"
|
||||||
@ -109,7 +110,7 @@ type launchTestSuite struct {
|
|||||||
projectMgr project.Manager
|
projectMgr project.Manager
|
||||||
execMgr *tasktesting.ExecutionManager
|
execMgr *tasktesting.ExecutionManager
|
||||||
taskMgr *tasktesting.Manager
|
taskMgr *tasktesting.Manager
|
||||||
repositoryMgr *repository.FakeManager
|
repositoryMgr *repository.Manager
|
||||||
retentionMgr Manager
|
retentionMgr Manager
|
||||||
jobserviceClient job.Client
|
jobserviceClient job.Client
|
||||||
}
|
}
|
||||||
@ -128,7 +129,7 @@ func (l *launchTestSuite) SetupTest() {
|
|||||||
pro1, pro2,
|
pro1, pro2,
|
||||||
}, nil)
|
}, nil)
|
||||||
l.projectMgr = projectMgr
|
l.projectMgr = projectMgr
|
||||||
l.repositoryMgr = &repository.FakeManager{}
|
l.repositoryMgr = &repository.Manager{}
|
||||||
l.retentionMgr = &fakeRetentionManager{}
|
l.retentionMgr = &fakeRetentionManager{}
|
||||||
l.execMgr = &tasktesting.ExecutionManager{}
|
l.execMgr = &tasktesting.ExecutionManager{}
|
||||||
l.taskMgr = &tasktesting.Manager{}
|
l.taskMgr = &tasktesting.Manager{}
|
||||||
@ -147,7 +148,7 @@ func (l *launchTestSuite) TestGetProjects() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *launchTestSuite) TestGetRepositories() {
|
func (l *launchTestSuite) TestGetRepositories() {
|
||||||
l.repositoryMgr.On("List").Return([]*models.RepoRecord{
|
l.repositoryMgr.On("List", mock.Anything, mock.Anything).Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
@ -200,7 +201,7 @@ func (l *launchTestSuite) TestLaunch() {
|
|||||||
require.NotNil(l.T(), err)
|
require.NotNil(l.T(), err)
|
||||||
|
|
||||||
// system scope
|
// system scope
|
||||||
l.repositoryMgr.On("List").Return([]*models.RepoRecord{
|
l.repositoryMgr.On("List", mock.Anything, mock.Anything).Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
ProjectID: 1,
|
ProjectID: 1,
|
||||||
|
@ -18,6 +18,7 @@ import (
|
|||||||
"github.com/goharbor/harbor/src/pkg/artifact"
|
"github.com/goharbor/harbor/src/pkg/artifact"
|
||||||
immu_model "github.com/goharbor/harbor/src/pkg/immutable/model"
|
immu_model "github.com/goharbor/harbor/src/pkg/immutable/model"
|
||||||
"github.com/goharbor/harbor/src/pkg/repository"
|
"github.com/goharbor/harbor/src/pkg/repository"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/pkg/tag"
|
"github.com/goharbor/harbor/src/pkg/tag"
|
||||||
tag_model "github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
tag_model "github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
||||||
"github.com/opencontainers/go-digest"
|
"github.com/opencontainers/go-digest"
|
||||||
@ -96,7 +97,7 @@ func (suite *HandlerSuite) addArt(ctx context.Context, pid, repositoryID int64,
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (suite *HandlerSuite) addRepo(ctx context.Context, pid int64, repo string) int64 {
|
func (suite *HandlerSuite) addRepo(ctx context.Context, pid int64, repo string) int64 {
|
||||||
repoRec := &models.RepoRecord{
|
repoRec := &model.RepoRecord{
|
||||||
Name: repo,
|
Name: repo,
|
||||||
ProjectID: pid,
|
ProjectID: pid,
|
||||||
}
|
}
|
||||||
|
@ -16,8 +16,8 @@ package registry
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/pkg/repository"
|
"github.com/goharbor/harbor/src/pkg/repository"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/testing/mock"
|
"github.com/goharbor/harbor/src/testing/mock"
|
||||||
repotesting "github.com/goharbor/harbor/src/testing/pkg/repository"
|
repotesting "github.com/goharbor/harbor/src/testing/pkg/repository"
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
@ -29,7 +29,7 @@ import (
|
|||||||
type catalogTestSuite struct {
|
type catalogTestSuite struct {
|
||||||
suite.Suite
|
suite.Suite
|
||||||
originalRepoMgr repository.Manager
|
originalRepoMgr repository.Manager
|
||||||
repoMgr *repotesting.FakeManager
|
repoMgr *repotesting.Manager
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *catalogTestSuite) SetupSuite() {
|
func (c *catalogTestSuite) SetupSuite() {
|
||||||
@ -37,7 +37,7 @@ func (c *catalogTestSuite) SetupSuite() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *catalogTestSuite) SetupTest() {
|
func (c *catalogTestSuite) SetupTest() {
|
||||||
c.repoMgr = &repotesting.FakeManager{}
|
c.repoMgr = &repotesting.Manager{}
|
||||||
repository.Mgr = c.repoMgr
|
repository.Mgr = c.repoMgr
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -52,7 +52,7 @@ func (c *catalogTestSuite) TestCatalog() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
mock.OnAnything(c.repoMgr, "NonEmptyRepos").Return([]*models.RepoRecord{
|
mock.OnAnything(c.repoMgr, "NonEmptyRepos").Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
@ -78,7 +78,7 @@ func (c *catalogTestSuite) TestCatalog() {
|
|||||||
func (c *catalogTestSuite) TestCatalogPaginationN1() {
|
func (c *catalogTestSuite) TestCatalogPaginationN1() {
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog?n=1", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog?n=1", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoMgr.On("NonEmptyRepos").Return([]*models.RepoRecord{
|
mock.OnAnything(c.repoMgr, "NonEmptyRepos").Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
@ -104,7 +104,7 @@ func (c *catalogTestSuite) TestCatalogPaginationN1() {
|
|||||||
func (c *catalogTestSuite) TestCatalogPaginationN2() {
|
func (c *catalogTestSuite) TestCatalogPaginationN2() {
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog?n=3", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog?n=3", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoMgr.On("NonEmptyRepos").Return([]*models.RepoRecord{
|
mock.OnAnything(c.repoMgr, "NonEmptyRepos").Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
@ -130,7 +130,7 @@ func (c *catalogTestSuite) TestCatalogPaginationN2() {
|
|||||||
func (c *catalogTestSuite) TestCatalogPaginationN3() {
|
func (c *catalogTestSuite) TestCatalogPaginationN3() {
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog?last=busybox&n=1", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog?last=busybox&n=1", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoMgr.On("NonEmptyRepos").Return([]*models.RepoRecord{
|
mock.OnAnything(c.repoMgr, "NonEmptyRepos").Return([]*model.RepoRecord{
|
||||||
{
|
{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
@ -156,7 +156,7 @@ func (c *catalogTestSuite) TestCatalogPaginationN3() {
|
|||||||
func (c *catalogTestSuite) TestCatalogEmptyRepo() {
|
func (c *catalogTestSuite) TestCatalogEmptyRepo() {
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/_catalog", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoMgr.On("NonEmptyRepos").Return([]*models.RepoRecord{}, nil)
|
mock.OnAnything(c.repoMgr, "NonEmptyRepos").Return([]*model.RepoRecord{}, nil)
|
||||||
w = httptest.NewRecorder()
|
w = httptest.NewRecorder()
|
||||||
newRepositoryHandler().ServeHTTP(w, req)
|
newRepositoryHandler().ServeHTTP(w, req)
|
||||||
c.Equal(http.StatusOK, w.Code)
|
c.Equal(http.StatusOK, w.Code)
|
||||||
|
@ -36,7 +36,7 @@ type manifestTestSuite struct {
|
|||||||
originalRepoCtl repository.Controller
|
originalRepoCtl repository.Controller
|
||||||
originalArtCtl artifact.Controller
|
originalArtCtl artifact.Controller
|
||||||
originalProxy http.Handler
|
originalProxy http.Handler
|
||||||
repoCtl *repotesting.FakeController
|
repoCtl *repotesting.Controller
|
||||||
artCtl *arttesting.Controller
|
artCtl *arttesting.Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ func (m *manifestTestSuite) SetupSuite() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *manifestTestSuite) SetupTest() {
|
func (m *manifestTestSuite) SetupTest() {
|
||||||
m.repoCtl = &repotesting.FakeController{}
|
m.repoCtl = &repotesting.Controller{}
|
||||||
m.artCtl = &arttesting.Controller{}
|
m.artCtl = &arttesting.Controller{}
|
||||||
repository.Ctl = m.repoCtl
|
repository.Ctl = m.repoCtl
|
||||||
artifact.Ctl = m.artCtl
|
artifact.Ctl = m.artCtl
|
||||||
@ -141,7 +141,7 @@ func (m *manifestTestSuite) TestPutManifest() {
|
|||||||
})
|
})
|
||||||
req := httptest.NewRequest(http.MethodPut, "/v2/library/hello-world/manifests/latest", nil)
|
req := httptest.NewRequest(http.MethodPut, "/v2/library/hello-world/manifests/latest", nil)
|
||||||
w := &httptest.ResponseRecorder{}
|
w := &httptest.ResponseRecorder{}
|
||||||
m.repoCtl.On("Ensure").Return(false, 1, nil)
|
mock.OnAnything(m.repoCtl, "Ensure").Return(false, int64(1), nil)
|
||||||
putManifest(w, req)
|
putManifest(w, req)
|
||||||
m.Equal(http.StatusInternalServerError, w.Code)
|
m.Equal(http.StatusInternalServerError, w.Code)
|
||||||
|
|
||||||
@ -159,7 +159,7 @@ func (m *manifestTestSuite) TestPutManifest() {
|
|||||||
})
|
})
|
||||||
req = httptest.NewRequest(http.MethodPut, "/v2/library/hello-world/manifests/latest", nil)
|
req = httptest.NewRequest(http.MethodPut, "/v2/library/hello-world/manifests/latest", nil)
|
||||||
w = &httptest.ResponseRecorder{}
|
w = &httptest.ResponseRecorder{}
|
||||||
m.repoCtl.On("Ensure").Return(false, 1, nil)
|
mock.OnAnything(m.repoCtl, "Ensure").Return(false, int64(1), nil)
|
||||||
mock.OnAnything(m.artCtl, "Ensure").Return(true, int64(1), nil)
|
mock.OnAnything(m.artCtl, "Ensure").Return(true, int64(1), nil)
|
||||||
putManifest(w, req)
|
putManifest(w, req)
|
||||||
m.Equal(http.StatusCreated, w.Code)
|
m.Equal(http.StatusCreated, w.Code)
|
||||||
|
@ -16,12 +16,13 @@ package registry
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/controller/repository"
|
"github.com/goharbor/harbor/src/controller/repository"
|
||||||
"github.com/goharbor/harbor/src/controller/tag"
|
"github.com/goharbor/harbor/src/controller/tag"
|
||||||
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
model_tag "github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
model_tag "github.com/goharbor/harbor/src/pkg/tag/model/tag"
|
||||||
repotesting "github.com/goharbor/harbor/src/testing/controller/repository"
|
repotesting "github.com/goharbor/harbor/src/testing/controller/repository"
|
||||||
tagtesting "github.com/goharbor/harbor/src/testing/controller/tag"
|
tagtesting "github.com/goharbor/harbor/src/testing/controller/tag"
|
||||||
|
"github.com/goharbor/harbor/src/testing/mock"
|
||||||
"github.com/stretchr/testify/suite"
|
"github.com/stretchr/testify/suite"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
@ -31,7 +32,7 @@ import (
|
|||||||
type tagTestSuite struct {
|
type tagTestSuite struct {
|
||||||
suite.Suite
|
suite.Suite
|
||||||
originalRepoCtl repository.Controller
|
originalRepoCtl repository.Controller
|
||||||
repoCtl *repotesting.FakeController
|
repoCtl *repotesting.Controller
|
||||||
originalTagCtl tag.Controller
|
originalTagCtl tag.Controller
|
||||||
tagCtl *tagtesting.FakeController
|
tagCtl *tagtesting.FakeController
|
||||||
}
|
}
|
||||||
@ -42,7 +43,7 @@ func (c *tagTestSuite) SetupSuite() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *tagTestSuite) SetupTest() {
|
func (c *tagTestSuite) SetupTest() {
|
||||||
c.repoCtl = &repotesting.FakeController{}
|
c.repoCtl = &repotesting.Controller{}
|
||||||
repository.Ctl = c.repoCtl
|
repository.Ctl = c.repoCtl
|
||||||
c.tagCtl = &tagtesting.FakeController{}
|
c.tagCtl = &tagtesting.FakeController{}
|
||||||
tag.Ctl = c.tagCtl
|
tag.Ctl = c.tagCtl
|
||||||
@ -60,7 +61,7 @@ func (c *tagTestSuite) TestListTag() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/library/hello-world/tags/list", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/library/hello-world/tags/list", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoCtl.On("GetByName").Return(&models.RepoRecord{
|
mock.OnAnything(c.repoCtl, "GetByName").Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "library/hello-world",
|
Name: "library/hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
@ -95,7 +96,7 @@ func (c *tagTestSuite) TestListTagPagination1() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/hello-world/tags/list?n=1", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/hello-world/tags/list?n=1", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoCtl.On("GetByName").Return(&models.RepoRecord{
|
mock.OnAnything(c.repoCtl, "GetByName").Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
@ -131,7 +132,7 @@ func (c *tagTestSuite) TestListTagPagination2() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/hello-world/tags/list?n=3", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/hello-world/tags/list?n=3", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoCtl.On("GetByName").Return(&models.RepoRecord{
|
mock.OnAnything(c.repoCtl, "GetByName").Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
@ -167,7 +168,7 @@ func (c *tagTestSuite) TestListTagPagination3() {
|
|||||||
c.SetupTest()
|
c.SetupTest()
|
||||||
req := httptest.NewRequest(http.MethodGet, "/v2/hello-world/tags/list?last=v1&n=1", nil)
|
req := httptest.NewRequest(http.MethodGet, "/v2/hello-world/tags/list?last=v1&n=1", nil)
|
||||||
var w *httptest.ResponseRecorder
|
var w *httptest.ResponseRecorder
|
||||||
c.repoCtl.On("GetByName").Return(&models.RepoRecord{
|
mock.OnAnything(c.repoCtl, "GetByName").Return(&model.RepoRecord{
|
||||||
RepositoryID: 1,
|
RepositoryID: 1,
|
||||||
Name: "hello-world",
|
Name: "hello-world",
|
||||||
}, nil)
|
}, nil)
|
||||||
|
@ -2,13 +2,13 @@ package model
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/go-openapi/strfmt"
|
"github.com/go-openapi/strfmt"
|
||||||
common_models "github.com/goharbor/harbor/src/common/models"
|
"github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/server/v2.0/models"
|
"github.com/goharbor/harbor/src/server/v2.0/models"
|
||||||
)
|
)
|
||||||
|
|
||||||
// RepoRecord model
|
// RepoRecord model
|
||||||
type RepoRecord struct {
|
type RepoRecord struct {
|
||||||
*common_models.RepoRecord
|
*model.RepoRecord
|
||||||
}
|
}
|
||||||
|
|
||||||
// ToSwagger converts the repository into the swagger model
|
// ToSwagger converts the repository into the swagger model
|
||||||
@ -25,6 +25,6 @@ func (r *RepoRecord) ToSwagger() *models.Repository {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NewRepoRecord ...
|
// NewRepoRecord ...
|
||||||
func NewRepoRecord(r *common_models.RepoRecord) *RepoRecord {
|
func NewRepoRecord(r *model.RepoRecord) *RepoRecord {
|
||||||
return &RepoRecord{RepoRecord: r}
|
return &RepoRecord{RepoRecord: r}
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,6 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/go-openapi/runtime/middleware"
|
"github.com/go-openapi/runtime/middleware"
|
||||||
cmodels "github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/common/rbac"
|
"github.com/goharbor/harbor/src/common/rbac"
|
||||||
"github.com/goharbor/harbor/src/common/security"
|
"github.com/goharbor/harbor/src/common/security"
|
||||||
"github.com/goharbor/harbor/src/common/security/local"
|
"github.com/goharbor/harbor/src/common/security/local"
|
||||||
@ -31,6 +30,7 @@ import (
|
|||||||
"github.com/goharbor/harbor/src/lib/log"
|
"github.com/goharbor/harbor/src/lib/log"
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
"github.com/goharbor/harbor/src/lib/q"
|
||||||
"github.com/goharbor/harbor/src/pkg/notification"
|
"github.com/goharbor/harbor/src/pkg/notification"
|
||||||
|
repomodel "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/goharbor/harbor/src/server/v2.0/handler/model"
|
"github.com/goharbor/harbor/src/server/v2.0/handler/model"
|
||||||
"github.com/goharbor/harbor/src/server/v2.0/models"
|
"github.com/goharbor/harbor/src/server/v2.0/models"
|
||||||
operation "github.com/goharbor/harbor/src/server/v2.0/restapi/operations/repository"
|
operation "github.com/goharbor/harbor/src/server/v2.0/restapi/operations/repository"
|
||||||
@ -209,7 +209,7 @@ func (r *repositoryAPI) UpdateRepository(ctx context.Context, params operation.U
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return r.SendError(ctx, err)
|
return r.SendError(ctx, err)
|
||||||
}
|
}
|
||||||
if err := r.repoCtl.Update(ctx, &cmodels.RepoRecord{
|
if err := r.repoCtl.Update(ctx, &repomodel.RepoRecord{
|
||||||
RepositoryID: repository.RepositoryID,
|
RepositoryID: repository.RepositoryID,
|
||||||
Description: params.Repository.Description,
|
Description: params.Repository.Description,
|
||||||
}, "Description"); err != nil {
|
}, "Description"); err != nil {
|
||||||
|
@ -27,3 +27,4 @@ package controller
|
|||||||
//go:generate mockery --case snake --dir ../../controller/retention --name Controller --output ./retention --outpkg retention
|
//go:generate mockery --case snake --dir ../../controller/retention --name Controller --output ./retention --outpkg retention
|
||||||
//go:generate mockery --case snake --dir ../../controller/config --name Controller --output ./config --outpkg config
|
//go:generate mockery --case snake --dir ../../controller/config --name Controller --output ./config --outpkg config
|
||||||
//go:generate mockery --case snake --dir ../../controller/user --name Controller --output ./user --outpkg user
|
//go:generate mockery --case snake --dir ../../controller/user --name Controller --output ./user --outpkg user
|
||||||
|
//go:generate mockery --case snake --dir ../../controller/repository --name Controller --output ./repository --outpkg repository
|
||||||
|
@ -1,89 +1,184 @@
|
|||||||
// Copyright Project Harbor Authors
|
// Code generated by mockery v2.1.0. DO NOT EDIT.
|
||||||
//
|
|
||||||
// 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 repository
|
package repository
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
context "context"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
model "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/stretchr/testify/mock"
|
mock "github.com/stretchr/testify/mock"
|
||||||
|
|
||||||
|
q "github.com/goharbor/harbor/src/lib/q"
|
||||||
)
|
)
|
||||||
|
|
||||||
// FakeController is a fake repository controller that implement src/api/repository.Controller interface
|
// Controller is an autogenerated mock type for the Controller type
|
||||||
type FakeController struct {
|
type Controller struct {
|
||||||
mock.Mock
|
mock.Mock
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure ...
|
// AddPullCount provides a mock function with given fields: ctx, id
|
||||||
func (f *FakeController) Ensure(ctx context.Context, name string) (bool, int64, error) {
|
func (_m *Controller) AddPullCount(ctx context.Context, id int64) error {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, id)
|
||||||
return args.Bool(0), int64(args.Int(1)), args.Error(2)
|
|
||||||
|
var r0 error
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, int64) error); ok {
|
||||||
|
r0 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Error(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Count ...
|
return r0
|
||||||
func (f *FakeController) Count(ctx context.Context, query *q.Query) (int64, error) {
|
|
||||||
args := f.Called()
|
|
||||||
return int64(args.Int(0)), args.Error(1)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// List ...
|
// Count provides a mock function with given fields: ctx, query
|
||||||
func (f *FakeController) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, error) {
|
func (_m *Controller) Count(ctx context.Context, query *q.Query) (int64, error) {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, query)
|
||||||
var repositories []*models.RepoRecord
|
|
||||||
if args.Get(0) != nil {
|
|
||||||
repositories = args.Get(0).([]*models.RepoRecord)
|
|
||||||
}
|
|
||||||
return repositories, args.Error(1)
|
|
||||||
|
|
||||||
|
var r0 int64
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, *q.Query) int64); ok {
|
||||||
|
r0 = rf(ctx, query)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Get(0).(int64)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get ...
|
var r1 error
|
||||||
func (f *FakeController) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
if rf, ok := ret.Get(1).(func(context.Context, *q.Query) error); ok {
|
||||||
args := f.Called()
|
r1 = rf(ctx, query)
|
||||||
var repository *models.RepoRecord
|
} else {
|
||||||
if args.Get(0) != nil {
|
r1 = ret.Error(1)
|
||||||
repository = args.Get(0).(*models.RepoRecord)
|
|
||||||
}
|
|
||||||
return repository, args.Error(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetByName ...
|
return r0, r1
|
||||||
func (f *FakeController) GetByName(ctx context.Context, name string) (*models.RepoRecord, error) {
|
|
||||||
args := f.Called()
|
|
||||||
var repository *models.RepoRecord
|
|
||||||
if args.Get(0) != nil {
|
|
||||||
repository = args.Get(0).(*models.RepoRecord)
|
|
||||||
}
|
|
||||||
return repository, args.Error(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete ...
|
// Delete provides a mock function with given fields: ctx, id
|
||||||
func (f *FakeController) Delete(ctx context.Context, id int64) error {
|
func (_m *Controller) Delete(ctx context.Context, id int64) error {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, id)
|
||||||
return args.Error(0)
|
|
||||||
|
var r0 error
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, int64) error); ok {
|
||||||
|
r0 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Error(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update ...
|
return r0
|
||||||
func (f *FakeController) Update(ctx context.Context, repository *models.RepoRecord, properties ...string) error {
|
|
||||||
args := f.Called()
|
|
||||||
return args.Error(0)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// AddPullCount ...
|
// Ensure provides a mock function with given fields: ctx, name
|
||||||
func (f *FakeController) AddPullCount(ctx context.Context, id int64) error {
|
func (_m *Controller) Ensure(ctx context.Context, name string) (bool, int64, error) {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, name)
|
||||||
return args.Error(0)
|
|
||||||
|
var r0 bool
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, string) bool); ok {
|
||||||
|
r0 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Get(0).(bool)
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 int64
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, string) int64); ok {
|
||||||
|
r1 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Get(1).(int64)
|
||||||
|
}
|
||||||
|
|
||||||
|
var r2 error
|
||||||
|
if rf, ok := ret.Get(2).(func(context.Context, string) error); ok {
|
||||||
|
r2 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
r2 = ret.Error(2)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1, r2
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get provides a mock function with given fields: ctx, id
|
||||||
|
func (_m *Controller) Get(ctx context.Context, id int64) (*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx, id)
|
||||||
|
|
||||||
|
var r0 *model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, int64) *model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).(*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, int64) error); ok {
|
||||||
|
r1 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetByName provides a mock function with given fields: ctx, name
|
||||||
|
func (_m *Controller) GetByName(ctx context.Context, name string) (*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx, name)
|
||||||
|
|
||||||
|
var r0 *model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, string) *model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).(*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, string) error); ok {
|
||||||
|
r1 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// List provides a mock function with given fields: ctx, query
|
||||||
|
func (_m *Controller) List(ctx context.Context, query *q.Query) ([]*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx, query)
|
||||||
|
|
||||||
|
var r0 []*model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, *q.Query) []*model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx, query)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).([]*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, *q.Query) error); ok {
|
||||||
|
r1 = rf(ctx, query)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update provides a mock function with given fields: ctx, _a1, properties
|
||||||
|
func (_m *Controller) Update(ctx context.Context, _a1 *model.RepoRecord, properties ...string) error {
|
||||||
|
_va := make([]interface{}, len(properties))
|
||||||
|
for _i := range properties {
|
||||||
|
_va[_i] = properties[_i]
|
||||||
|
}
|
||||||
|
var _ca []interface{}
|
||||||
|
_ca = append(_ca, ctx, _a1)
|
||||||
|
_ca = append(_ca, _va...)
|
||||||
|
ret := _m.Called(_ca...)
|
||||||
|
|
||||||
|
var r0 error
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, *model.RepoRecord, ...string) error); ok {
|
||||||
|
r0 = rf(ctx, _a1, properties...)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,7 @@ package pkg
|
|||||||
//go:generate mockery --case snake --dir ../../pkg/rbac/dao --name DAO --output ./rbac/dao --outpkg dao
|
//go:generate mockery --case snake --dir ../../pkg/rbac/dao --name DAO --output ./rbac/dao --outpkg dao
|
||||||
//go:generate mockery --case snake --dir ../../pkg/robot --name Manager --output ./robot --outpkg robot
|
//go:generate mockery --case snake --dir ../../pkg/robot --name Manager --output ./robot --outpkg robot
|
||||||
//go:generate mockery --case snake --dir ../../pkg/robot/dao --name DAO --output ./robot/dao --outpkg dao
|
//go:generate mockery --case snake --dir ../../pkg/robot/dao --name DAO --output ./robot/dao --outpkg dao
|
||||||
|
//go:generate mockery --case snake --dir ../../pkg/repository --name Manager --output ./repository --outpkg repository
|
||||||
//go:generate mockery --case snake --dir ../../pkg/repository/dao --name DAO --output ./repository/dao --outpkg dao
|
//go:generate mockery --case snake --dir ../../pkg/repository/dao --name DAO --output ./repository/dao --outpkg dao
|
||||||
//go:generate mockery --case snake --dir ../../pkg/notification/job/dao --name DAO --output ./notification/job/dao --outpkg dao
|
//go:generate mockery --case snake --dir ../../pkg/notification/job/dao --name DAO --output ./notification/job/dao --outpkg dao
|
||||||
//go:generate mockery --case snake --dir ../../pkg/notification/policy/dao --name DAO --output ./notification/policy/dao --outpkg dao
|
//go:generate mockery --case snake --dir ../../pkg/notification/policy/dao --name DAO --output ./notification/policy/dao --outpkg dao
|
||||||
|
@ -7,7 +7,7 @@ import (
|
|||||||
|
|
||||||
mock "github.com/stretchr/testify/mock"
|
mock "github.com/stretchr/testify/mock"
|
||||||
|
|
||||||
models "github.com/goharbor/harbor/src/common/models"
|
models "github.com/goharbor/harbor/src/pkg/project/metadata/models"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Manager is an autogenerated mock type for the Manager type
|
// Manager is an autogenerated mock type for the Manager type
|
||||||
|
@ -7,7 +7,7 @@ import (
|
|||||||
|
|
||||||
mock "github.com/stretchr/testify/mock"
|
mock "github.com/stretchr/testify/mock"
|
||||||
|
|
||||||
models "github.com/goharbor/harbor/src/common/models"
|
model "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
|
|
||||||
q "github.com/goharbor/harbor/src/lib/q"
|
q "github.com/goharbor/harbor/src/lib/q"
|
||||||
)
|
)
|
||||||
@ -53,18 +53,18 @@ func (_m *DAO) Count(ctx context.Context, query *q.Query) (int64, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create provides a mock function with given fields: ctx, repository
|
// Create provides a mock function with given fields: ctx, repository
|
||||||
func (_m *DAO) Create(ctx context.Context, repository *models.RepoRecord) (int64, error) {
|
func (_m *DAO) Create(ctx context.Context, repository *model.RepoRecord) (int64, error) {
|
||||||
ret := _m.Called(ctx, repository)
|
ret := _m.Called(ctx, repository)
|
||||||
|
|
||||||
var r0 int64
|
var r0 int64
|
||||||
if rf, ok := ret.Get(0).(func(context.Context, *models.RepoRecord) int64); ok {
|
if rf, ok := ret.Get(0).(func(context.Context, *model.RepoRecord) int64); ok {
|
||||||
r0 = rf(ctx, repository)
|
r0 = rf(ctx, repository)
|
||||||
} else {
|
} else {
|
||||||
r0 = ret.Get(0).(int64)
|
r0 = ret.Get(0).(int64)
|
||||||
}
|
}
|
||||||
|
|
||||||
var r1 error
|
var r1 error
|
||||||
if rf, ok := ret.Get(1).(func(context.Context, *models.RepoRecord) error); ok {
|
if rf, ok := ret.Get(1).(func(context.Context, *model.RepoRecord) error); ok {
|
||||||
r1 = rf(ctx, repository)
|
r1 = rf(ctx, repository)
|
||||||
} else {
|
} else {
|
||||||
r1 = ret.Error(1)
|
r1 = ret.Error(1)
|
||||||
@ -88,15 +88,15 @@ func (_m *DAO) Delete(ctx context.Context, id int64) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Get provides a mock function with given fields: ctx, id
|
// Get provides a mock function with given fields: ctx, id
|
||||||
func (_m *DAO) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
func (_m *DAO) Get(ctx context.Context, id int64) (*model.RepoRecord, error) {
|
||||||
ret := _m.Called(ctx, id)
|
ret := _m.Called(ctx, id)
|
||||||
|
|
||||||
var r0 *models.RepoRecord
|
var r0 *model.RepoRecord
|
||||||
if rf, ok := ret.Get(0).(func(context.Context, int64) *models.RepoRecord); ok {
|
if rf, ok := ret.Get(0).(func(context.Context, int64) *model.RepoRecord); ok {
|
||||||
r0 = rf(ctx, id)
|
r0 = rf(ctx, id)
|
||||||
} else {
|
} else {
|
||||||
if ret.Get(0) != nil {
|
if ret.Get(0) != nil {
|
||||||
r0 = ret.Get(0).(*models.RepoRecord)
|
r0 = ret.Get(0).(*model.RepoRecord)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,15 +111,15 @@ func (_m *DAO) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// List provides a mock function with given fields: ctx, query
|
// List provides a mock function with given fields: ctx, query
|
||||||
func (_m *DAO) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, error) {
|
func (_m *DAO) List(ctx context.Context, query *q.Query) ([]*model.RepoRecord, error) {
|
||||||
ret := _m.Called(ctx, query)
|
ret := _m.Called(ctx, query)
|
||||||
|
|
||||||
var r0 []*models.RepoRecord
|
var r0 []*model.RepoRecord
|
||||||
if rf, ok := ret.Get(0).(func(context.Context, *q.Query) []*models.RepoRecord); ok {
|
if rf, ok := ret.Get(0).(func(context.Context, *q.Query) []*model.RepoRecord); ok {
|
||||||
r0 = rf(ctx, query)
|
r0 = rf(ctx, query)
|
||||||
} else {
|
} else {
|
||||||
if ret.Get(0) != nil {
|
if ret.Get(0) != nil {
|
||||||
r0 = ret.Get(0).([]*models.RepoRecord)
|
r0 = ret.Get(0).([]*model.RepoRecord)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -134,15 +134,15 @@ func (_m *DAO) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NonEmptyRepos provides a mock function with given fields: ctx
|
// NonEmptyRepos provides a mock function with given fields: ctx
|
||||||
func (_m *DAO) NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error) {
|
func (_m *DAO) NonEmptyRepos(ctx context.Context) ([]*model.RepoRecord, error) {
|
||||||
ret := _m.Called(ctx)
|
ret := _m.Called(ctx)
|
||||||
|
|
||||||
var r0 []*models.RepoRecord
|
var r0 []*model.RepoRecord
|
||||||
if rf, ok := ret.Get(0).(func(context.Context) []*models.RepoRecord); ok {
|
if rf, ok := ret.Get(0).(func(context.Context) []*model.RepoRecord); ok {
|
||||||
r0 = rf(ctx)
|
r0 = rf(ctx)
|
||||||
} else {
|
} else {
|
||||||
if ret.Get(0) != nil {
|
if ret.Get(0) != nil {
|
||||||
r0 = ret.Get(0).([]*models.RepoRecord)
|
r0 = ret.Get(0).([]*model.RepoRecord)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,7 +157,7 @@ func (_m *DAO) NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Update provides a mock function with given fields: ctx, repository, props
|
// Update provides a mock function with given fields: ctx, repository, props
|
||||||
func (_m *DAO) Update(ctx context.Context, repository *models.RepoRecord, props ...string) error {
|
func (_m *DAO) Update(ctx context.Context, repository *model.RepoRecord, props ...string) error {
|
||||||
_va := make([]interface{}, len(props))
|
_va := make([]interface{}, len(props))
|
||||||
for _i := range props {
|
for _i := range props {
|
||||||
_va[_i] = props[_i]
|
_va[_i] = props[_i]
|
||||||
@ -168,7 +168,7 @@ func (_m *DAO) Update(ctx context.Context, repository *models.RepoRecord, props
|
|||||||
ret := _m.Called(_ca...)
|
ret := _m.Called(_ca...)
|
||||||
|
|
||||||
var r0 error
|
var r0 error
|
||||||
if rf, ok := ret.Get(0).(func(context.Context, *models.RepoRecord, ...string) error); ok {
|
if rf, ok := ret.Get(0).(func(context.Context, *model.RepoRecord, ...string) error); ok {
|
||||||
r0 = rf(ctx, repository, props...)
|
r0 = rf(ctx, repository, props...)
|
||||||
} else {
|
} else {
|
||||||
r0 = ret.Error(0)
|
r0 = ret.Error(0)
|
||||||
|
@ -1,97 +1,200 @@
|
|||||||
// Copyright Project Harbor Authors
|
// Code generated by mockery v2.1.0. DO NOT EDIT.
|
||||||
//
|
|
||||||
// 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 repository
|
package repository
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
context "context"
|
||||||
"github.com/goharbor/harbor/src/common/models"
|
|
||||||
"github.com/goharbor/harbor/src/lib/q"
|
model "github.com/goharbor/harbor/src/pkg/repository/model"
|
||||||
"github.com/stretchr/testify/mock"
|
mock "github.com/stretchr/testify/mock"
|
||||||
|
|
||||||
|
q "github.com/goharbor/harbor/src/lib/q"
|
||||||
)
|
)
|
||||||
|
|
||||||
// FakeManager is a fake repository manager that implement src/pkg/repository.Manager interface
|
// Manager is an autogenerated mock type for the Manager type
|
||||||
type FakeManager struct {
|
type Manager struct {
|
||||||
mock.Mock
|
mock.Mock
|
||||||
}
|
}
|
||||||
|
|
||||||
// Count ...
|
// AddPullCount provides a mock function with given fields: ctx, id
|
||||||
func (f *FakeManager) Count(ctx context.Context, query *q.Query) (int64, error) {
|
func (_m *Manager) AddPullCount(ctx context.Context, id int64) error {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, id)
|
||||||
return int64(args.Int(0)), args.Error(1)
|
|
||||||
|
var r0 error
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, int64) error); ok {
|
||||||
|
r0 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Error(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
// List ...
|
return r0
|
||||||
func (f *FakeManager) List(ctx context.Context, query *q.Query) ([]*models.RepoRecord, error) {
|
|
||||||
args := f.Called()
|
|
||||||
var repositories []*models.RepoRecord
|
|
||||||
if args.Get(0) != nil {
|
|
||||||
repositories = args.Get(0).([]*models.RepoRecord)
|
|
||||||
}
|
|
||||||
return repositories, args.Error(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get ...
|
// Count provides a mock function with given fields: ctx, query
|
||||||
func (f *FakeManager) Get(ctx context.Context, id int64) (*models.RepoRecord, error) {
|
func (_m *Manager) Count(ctx context.Context, query *q.Query) (int64, error) {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, query)
|
||||||
var repository *models.RepoRecord
|
|
||||||
if args.Get(0) != nil {
|
var r0 int64
|
||||||
repository = args.Get(0).(*models.RepoRecord)
|
if rf, ok := ret.Get(0).(func(context.Context, *q.Query) int64); ok {
|
||||||
}
|
r0 = rf(ctx, query)
|
||||||
return repository, args.Error(1)
|
} else {
|
||||||
|
r0 = ret.Get(0).(int64)
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetByName ...
|
var r1 error
|
||||||
func (f *FakeManager) GetByName(ctx context.Context, name string) (*models.RepoRecord, error) {
|
if rf, ok := ret.Get(1).(func(context.Context, *q.Query) error); ok {
|
||||||
args := f.Called()
|
r1 = rf(ctx, query)
|
||||||
var repository *models.RepoRecord
|
} else {
|
||||||
if args.Get(0) != nil {
|
r1 = ret.Error(1)
|
||||||
repository = args.Get(0).(*models.RepoRecord)
|
|
||||||
}
|
|
||||||
return repository, args.Error(1)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete ...
|
return r0, r1
|
||||||
func (f *FakeManager) Delete(ctx context.Context, id int64) error {
|
|
||||||
args := f.Called()
|
|
||||||
return args.Error(0)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create ...
|
// Create provides a mock function with given fields: ctx, _a1
|
||||||
func (f *FakeManager) Create(ctx context.Context, repository *models.RepoRecord) (int64, error) {
|
func (_m *Manager) Create(ctx context.Context, _a1 *model.RepoRecord) (int64, error) {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, _a1)
|
||||||
return int64(args.Int(0)), args.Error(1)
|
|
||||||
|
var r0 int64
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, *model.RepoRecord) int64); ok {
|
||||||
|
r0 = rf(ctx, _a1)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Get(0).(int64)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update ...
|
var r1 error
|
||||||
func (f *FakeManager) Update(ctx context.Context, repository *models.RepoRecord, props ...string) error {
|
if rf, ok := ret.Get(1).(func(context.Context, *model.RepoRecord) error); ok {
|
||||||
args := f.Called()
|
r1 = rf(ctx, _a1)
|
||||||
return args.Error(0)
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
// AddPullCount ...
|
return r0, r1
|
||||||
func (f *FakeManager) AddPullCount(ctx context.Context, id int64) error {
|
|
||||||
args := f.Called()
|
|
||||||
return args.Error(0)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// NonEmptyRepos ...
|
// Delete provides a mock function with given fields: ctx, id
|
||||||
func (f *FakeManager) NonEmptyRepos(ctx context.Context) ([]*models.RepoRecord, error) {
|
func (_m *Manager) Delete(ctx context.Context, id int64) error {
|
||||||
args := f.Called()
|
ret := _m.Called(ctx, id)
|
||||||
var repository []*models.RepoRecord
|
|
||||||
if args.Get(0) != nil {
|
var r0 error
|
||||||
repository = args.Get(0).([]*models.RepoRecord)
|
if rf, ok := ret.Get(0).(func(context.Context, int64) error); ok {
|
||||||
|
r0 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Error(0)
|
||||||
}
|
}
|
||||||
return repository, args.Error(1)
|
|
||||||
|
return r0
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get provides a mock function with given fields: ctx, id
|
||||||
|
func (_m *Manager) Get(ctx context.Context, id int64) (*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx, id)
|
||||||
|
|
||||||
|
var r0 *model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, int64) *model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).(*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, int64) error); ok {
|
||||||
|
r1 = rf(ctx, id)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetByName provides a mock function with given fields: ctx, name
|
||||||
|
func (_m *Manager) GetByName(ctx context.Context, name string) (*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx, name)
|
||||||
|
|
||||||
|
var r0 *model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, string) *model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).(*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, string) error); ok {
|
||||||
|
r1 = rf(ctx, name)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// List provides a mock function with given fields: ctx, query
|
||||||
|
func (_m *Manager) List(ctx context.Context, query *q.Query) ([]*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx, query)
|
||||||
|
|
||||||
|
var r0 []*model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, *q.Query) []*model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx, query)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).([]*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context, *q.Query) error); ok {
|
||||||
|
r1 = rf(ctx, query)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// NonEmptyRepos provides a mock function with given fields: ctx
|
||||||
|
func (_m *Manager) NonEmptyRepos(ctx context.Context) ([]*model.RepoRecord, error) {
|
||||||
|
ret := _m.Called(ctx)
|
||||||
|
|
||||||
|
var r0 []*model.RepoRecord
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context) []*model.RepoRecord); ok {
|
||||||
|
r0 = rf(ctx)
|
||||||
|
} else {
|
||||||
|
if ret.Get(0) != nil {
|
||||||
|
r0 = ret.Get(0).([]*model.RepoRecord)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var r1 error
|
||||||
|
if rf, ok := ret.Get(1).(func(context.Context) error); ok {
|
||||||
|
r1 = rf(ctx)
|
||||||
|
} else {
|
||||||
|
r1 = ret.Error(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0, r1
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update provides a mock function with given fields: ctx, _a1, props
|
||||||
|
func (_m *Manager) Update(ctx context.Context, _a1 *model.RepoRecord, props ...string) error {
|
||||||
|
_va := make([]interface{}, len(props))
|
||||||
|
for _i := range props {
|
||||||
|
_va[_i] = props[_i]
|
||||||
|
}
|
||||||
|
var _ca []interface{}
|
||||||
|
_ca = append(_ca, ctx, _a1)
|
||||||
|
_ca = append(_ca, _va...)
|
||||||
|
ret := _m.Called(_ca...)
|
||||||
|
|
||||||
|
var r0 error
|
||||||
|
if rf, ok := ret.Get(0).(func(context.Context, *model.RepoRecord, ...string) error); ok {
|
||||||
|
r0 = rf(ctx, _a1, props...)
|
||||||
|
} else {
|
||||||
|
r0 = ret.Error(0)
|
||||||
|
}
|
||||||
|
|
||||||
|
return r0
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user