diff --git a/repos.go b/repos.go index 79fefab..6ccb040 100644 --- a/repos.go +++ b/repos.go @@ -98,7 +98,7 @@ func (s *RepoService) Migrate(ctx context.Context, opts *types.MigrateRepoOption // CreateOrgRepo creates a repository in an organisation. func (s *RepoService) CreateOrgRepo(ctx context.Context, org string, opts *types.CreateRepoOption) (*types.Repository, error) { - path := ResolvePath("/api/v1/org/{org}/repos", pathParams("org", org)) + path := ResolvePath("/api/v1/orgs/{org}/repos", pathParams("org", org)) var out types.Repository if err := s.client.Post(ctx, path, opts, &out); err != nil { return nil, err diff --git a/repos_test.go b/repos_test.go index 7da727e..a5616fc 100644 --- a/repos_test.go +++ b/repos_test.go @@ -2127,6 +2127,34 @@ func TestRepoService_PathParamsAreEscaped_Good(t *testing.T) { } }) + t.Run("CreateOrgRepo", func(t *testing.T) { + srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + want := "/api/v1/orgs/team%20alpha/repos" + if r.URL.EscapedPath() != want { + t.Errorf("got path %q, want %q", r.URL.EscapedPath(), want) + http.NotFound(w, r) + return + } + var opts types.CreateRepoOption + if err := json.NewDecoder(r.Body).Decode(&opts); err != nil { + t.Fatalf("decode body: %v", err) + } + if opts.Name != "go-forge" || !opts.Private { + t.Fatalf("got %#v", opts) + } + json.NewEncoder(w).Encode(types.Repository{Name: opts.Name}) + })) + defer srv.Close() + + f := NewForge(srv.URL, "tok") + if _, err := f.Repos.CreateOrgRepo(context.Background(), org, &types.CreateRepoOption{ + Name: "go-forge", + Private: true, + }); err != nil { + t.Fatal(err) + } + }) + t.Run("Fork", func(t *testing.T) { srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { want := "/api/v1/repos/acme%20org/my%2Frepo/forks"