mirror of
https://github.com/coder/coder.git
synced 2025-07-13 21:36:50 +00:00
fix: resolve template name from working directory "." (#6822)
This commit is contained in:
@ -85,8 +85,13 @@ func (pf *templateUploadFlags) templateName(args []string) (string, error) {
|
||||
if len(args) > 0 {
|
||||
return args[0], nil
|
||||
}
|
||||
// Have to take absPath to resolve "." and "..".
|
||||
absPath, err := filepath.Abs(pf.directory)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
// If no name is provided, use the directory name.
|
||||
return filepath.Base(pf.directory), nil
|
||||
return filepath.Base(absPath), nil
|
||||
}
|
||||
|
||||
func (r *RootCmd) templatePush() *clibase.Cmd {
|
||||
|
@ -155,8 +155,9 @@ func TestTemplatePush(t *testing.T) {
|
||||
require.Equal(t, "example", templateVersions[1].Name)
|
||||
})
|
||||
|
||||
// This test modifies the working directory.
|
||||
//nolint:paralleltest
|
||||
t.Run("UseWorkingDir", func(t *testing.T) {
|
||||
t.Parallel()
|
||||
client := coderdtest.New(t, &coderdtest.Options{IncludeProvisionerDaemon: true})
|
||||
user := coderdtest.CreateFirstUser(t, client)
|
||||
version := coderdtest.CreateTemplateVersion(t, client, user.OrganizationID, nil)
|
||||
@ -173,9 +174,18 @@ func TestTemplatePush(t *testing.T) {
|
||||
r.Name = filepath.Base(source)
|
||||
})
|
||||
|
||||
oldDir, err := os.Getwd()
|
||||
require.NoError(t, err)
|
||||
|
||||
os.Chdir(source)
|
||||
|
||||
t.Cleanup(func() {
|
||||
os.Chdir(oldDir)
|
||||
})
|
||||
|
||||
// Don't pass the name of the template, it should use the
|
||||
// directory of the source.
|
||||
inv, root := clitest.New(t, "templates", "push", "--directory", source, "--test.provisioner", string(database.ProvisionerTypeEcho))
|
||||
inv, root := clitest.New(t, "templates", "push", "--test.provisioner", string(database.ProvisionerTypeEcho))
|
||||
clitest.SetupConfig(t, client, root)
|
||||
pty := ptytest.New(t).Attach(inv)
|
||||
|
||||
|
@ -221,6 +221,9 @@ func (c *Client) TemplatesByOrganization(ctx context.Context, organizationID uui
|
||||
|
||||
// TemplateByName finds a template inside the organization provided with a case-insensitive name.
|
||||
func (c *Client) TemplateByName(ctx context.Context, organizationID uuid.UUID, name string) (Template, error) {
|
||||
if name == "" {
|
||||
return Template{}, xerrors.Errorf("template name cannot be empty")
|
||||
}
|
||||
res, err := c.Request(ctx, http.MethodGet,
|
||||
fmt.Sprintf("/api/v2/organizations/%s/templates/%s", organizationID.String(), name),
|
||||
nil,
|
||||
|
Reference in New Issue
Block a user