2022-08-29 09:04:45 +02:00
|
|
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
2022-11-27 19:20:29 +01:00
|
|
|
// SPDX-License-Identifier: MIT
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
package vagrant
|
|
|
|
|
|
|
|
import (
|
|
|
|
"archive/tar"
|
|
|
|
"bytes"
|
|
|
|
"compress/gzip"
|
|
|
|
"io"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"code.gitea.io/gitea/modules/json"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2024-07-30 21:42:06 +02:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-08-29 09:04:45 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
author = "gitea"
|
|
|
|
description = "Package Description"
|
|
|
|
projectURL = "https://gitea.io"
|
|
|
|
repositoryURL = "https://gitea.io/gitea/gitea"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestParseMetadataFromBox(t *testing.T) {
|
|
|
|
createArchive := func(files map[string][]byte) io.Reader {
|
|
|
|
var buf bytes.Buffer
|
|
|
|
zw := gzip.NewWriter(&buf)
|
|
|
|
tw := tar.NewWriter(zw)
|
|
|
|
for filename, content := range files {
|
|
|
|
hdr := &tar.Header{
|
|
|
|
Name: filename,
|
|
|
|
Mode: 0o600,
|
|
|
|
Size: int64(len(content)),
|
|
|
|
}
|
|
|
|
tw.WriteHeader(hdr)
|
|
|
|
tw.Write(content)
|
|
|
|
}
|
|
|
|
tw.Close()
|
|
|
|
zw.Close()
|
|
|
|
return &buf
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Run("MissingInfoFile", func(t *testing.T) {
|
|
|
|
data := createArchive(map[string][]byte{"dummy.txt": {}})
|
|
|
|
|
|
|
|
metadata, err := ParseMetadataFromBox(data)
|
|
|
|
assert.NotNil(t, metadata)
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Valid", func(t *testing.T) {
|
|
|
|
content, err := json.Marshal(map[string]string{
|
|
|
|
"description": description,
|
|
|
|
"author": author,
|
|
|
|
"website": projectURL,
|
|
|
|
"repository": repositoryURL,
|
|
|
|
})
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
data := createArchive(map[string][]byte{"info.json": content})
|
|
|
|
|
|
|
|
metadata, err := ParseMetadataFromBox(data)
|
|
|
|
assert.NotNil(t, metadata)
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
assert.Equal(t, author, metadata.Author)
|
|
|
|
assert.Equal(t, description, metadata.Description)
|
|
|
|
assert.Equal(t, projectURL, metadata.ProjectURL)
|
|
|
|
assert.Equal(t, repositoryURL, metadata.RepositoryURL)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseInfoFile(t *testing.T) {
|
|
|
|
t.Run("UnknownKeys", func(t *testing.T) {
|
|
|
|
content, err := json.Marshal(map[string]string{
|
|
|
|
"package": "",
|
|
|
|
"dummy": "",
|
|
|
|
})
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
metadata, err := ParseInfoFile(bytes.NewReader(content))
|
|
|
|
assert.NotNil(t, metadata)
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
assert.Empty(t, metadata.Author)
|
|
|
|
assert.Empty(t, metadata.Description)
|
|
|
|
assert.Empty(t, metadata.ProjectURL)
|
|
|
|
assert.Empty(t, metadata.RepositoryURL)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Valid", func(t *testing.T) {
|
|
|
|
content, err := json.Marshal(map[string]string{
|
|
|
|
"description": description,
|
|
|
|
"author": author,
|
|
|
|
"website": projectURL,
|
|
|
|
"repository": repositoryURL,
|
|
|
|
})
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
metadata, err := ParseInfoFile(bytes.NewReader(content))
|
|
|
|
assert.NotNil(t, metadata)
|
2024-07-30 21:42:06 +02:00
|
|
|
require.NoError(t, err)
|
2022-08-29 09:04:45 +02:00
|
|
|
|
|
|
|
assert.Equal(t, author, metadata.Author)
|
|
|
|
assert.Equal(t, description, metadata.Description)
|
|
|
|
assert.Equal(t, projectURL, metadata.ProjectURL)
|
|
|
|
assert.Equal(t, repositoryURL, metadata.RepositoryURL)
|
|
|
|
})
|
|
|
|
}
|