From 546f20c9d511f2a3a4593499c98b47e38a4a0e25 Mon Sep 17 00:00:00 2001 From: Billy Zha <515363446@qq.com> Date: Fri, 25 Mar 2022 14:39:46 +0800 Subject: [PATCH] Add example for listing repositories in registry target (#117) Signed-off-by: Billy Zha --- registry/registry_example_test.go | 75 +++++++++++++++++++++++ registry/remote/registry_example_test.go | 76 ++++++++++++++++++++++++ 2 files changed, 151 insertions(+) create mode 100644 registry/registry_example_test.go create mode 100644 registry/remote/registry_example_test.go diff --git a/registry/registry_example_test.go b/registry/registry_example_test.go new file mode 100644 index 00000000..c0692978 --- /dev/null +++ b/registry/registry_example_test.go @@ -0,0 +1,75 @@ +/* +Copyright The ORAS 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 registry_test gives examples code of functions in the registry package. +package registry_test + +import ( + "context" + "encoding/json" + "fmt" + "net/http" + "net/http/httptest" + "net/url" + "os" + "testing" + + "oras.land/oras-go/v2/registry" + "oras.land/oras-go/v2/registry/remote" +) + +var host string + +func TestMain(m *testing.M) { + // Setup a local HTTPS registry + ts := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + result := struct { + Repositories []string `json:"repositories"` + }{ + Repositories: []string{"public/repo1", "public/repo2", "internal/repo3"}, + } + json.NewEncoder(w).Encode(result) + })) + defer ts.Close() + u, err := url.Parse(ts.URL) + if err != nil { + panic(err) + } + host = u.Host + http.DefaultClient = ts.Client() + + os.Exit(m.Run()) +} + +// ExampleRepositories gives example snippets for listing respositories in the registry without pagination. +func ExampleRepositories() { + reg, err := remote.NewRegistry(host) + if err != nil { + panic(err) // Handle error + } + + ctx := context.Background() + repos, err := registry.Repositories(ctx, reg) + if err != nil { + panic(err) // Handle error + } + for _, repo := range repos { + fmt.Println(repo) + } + // Output: + // public/repo1 + // public/repo2 + // internal/repo3 +} diff --git a/registry/remote/registry_example_test.go b/registry/remote/registry_example_test.go new file mode 100644 index 00000000..01531164 --- /dev/null +++ b/registry/remote/registry_example_test.go @@ -0,0 +1,76 @@ +/* +Copyright The ORAS 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 registry_test gives examples code of functions in the remote package. +package remote_test + +import ( + "context" + "encoding/json" + "fmt" + "net/http" + "net/http/httptest" + "net/url" + "os" + "testing" + + "oras.land/oras-go/v2/registry/remote" +) + +var host string + +func TestMain(m *testing.M) { + // Setup mocked registries + httpsServer := httptest.NewTLSServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + result := struct { + Repositories []string `json:"repositories"` + }{ + Repositories: []string{"public/repo1", "public/repo2", "internal/repo3"}, + } + json.NewEncoder(w).Encode(result) + })) + defer httpsServer.Close() + u, err := url.Parse(httpsServer.URL) + if err != nil { + panic(err) + } + host = u.Host + http.DefaultClient = httpsServer.Client() + os.Exit(m.Run()) +} + +// ExampleRegistry_Repositories gives example snippets for listing respositories in a HTTPS registry with pagination. +func ExampleRegistry_Repositories() { + reg, err := remote.NewRegistry(host) + if err != nil { + panic(err) // Handle error + } + // If you want to play with your local registry, try to override + // the `host` variable. Don't forget to set HTTP option as below: + // reg.PlainHTTP = true + + ctx := context.Background() + err = reg.Repositories(ctx, func(repos []string) error { + for _, repo := range repos { + fmt.Println(repo) + } + return nil + }) + if err != nil { + panic(err) // Handle error + } + // Output: + // public/repo1 + // public/repo2 + // internal/repo3 +}