fix: allow example files to be reused and not error (#5402)

This commit is contained in:
Garrett Delfosse
2022-12-13 11:27:37 -05:00
committed by GitHub
parent 50d1c7191a
commit 560c8ce0f6
2 changed files with 36 additions and 9 deletions

View File

@ -878,21 +878,39 @@ func (api *API) postTemplateVersionsByOrganization(rw http.ResponseWriter, r *ht
// upload a copy of the template tar as a file in the database // upload a copy of the template tar as a file in the database
hashBytes := sha256.Sum256(tar) hashBytes := sha256.Sum256(tar)
hash := hex.EncodeToString(hashBytes[:]) hash := hex.EncodeToString(hashBytes[:])
file, err = api.Database.InsertFile(ctx, database.InsertFileParams{ // Check if the file already exists.
ID: uuid.New(), file, err := api.Database.GetFileByHashAndCreator(ctx, database.GetFileByHashAndCreatorParams{
Hash: hash, Hash: hash,
CreatedBy: apiKey.UserID, CreatedBy: apiKey.UserID,
CreatedAt: database.Now(),
Mimetype: tarMimeType,
Data: tar,
}) })
if err != nil { if err != nil {
httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{ if !errors.Is(err, sql.ErrNoRows) {
Message: "Internal error creating file.", httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{
Detail: err.Error(), Message: "Internal error fetching file.",
Detail: err.Error(),
})
return
}
// If the example tar file doesn't exist, create it.
file, err = api.Database.InsertFile(ctx, database.InsertFileParams{
ID: uuid.New(),
Hash: hash,
CreatedBy: apiKey.UserID,
CreatedAt: database.Now(),
Mimetype: tarMimeType,
Data: tar,
}) })
return if err != nil {
httpapi.Write(ctx, rw, http.StatusInternalServerError, codersdk.Response{
Message: "Internal error creating file.",
Detail: err.Error(),
})
return
}
} }
req.FileID = file.ID
} }
if req.FileID != uuid.Nil { if req.FileID != uuid.Nil {

View File

@ -179,6 +179,15 @@ func TestPostTemplateVersionsByOrganization(t *testing.T) {
tar, err := examples.Archive(ls[0].ID) tar, err := examples.Archive(ls[0].ID)
require.NoError(t, err) require.NoError(t, err)
require.EqualValues(t, tar, fl) require.EqualValues(t, tar, fl)
// ensure we don't get file conflicts on multiple uses of the same example
tv, err = client.CreateTemplateVersion(ctx, user.OrganizationID, codersdk.CreateTemplateVersionRequest{
Name: "my-example",
StorageMethod: codersdk.ProvisionerStorageMethodFile,
ExampleID: ls[0].ID,
Provisioner: codersdk.ProvisionerTypeEcho,
})
require.NoError(t, err)
}) })
} }