aboutsummaryrefslogtreecommitdiffstats
path: root/modules/assetfs/embed_test.go
blob: 06598da4c4e698d0ad015f8c5a8a6c6ab54570e7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// Copyright 2025 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT

package assetfs

import (
	"bytes"
	"io/fs"
	"net/http"
	"os"
	"testing"

	"github.com/stretchr/testify/assert"
	"github.com/stretchr/testify/require"
)

func TestEmbed(t *testing.T) {
	tmpDir := t.TempDir()
	tmpDataDir := tmpDir + "/data"
	_ = os.MkdirAll(tmpDataDir+"/foo/bar", 0o755)
	_ = os.WriteFile(tmpDataDir+"/a.txt", []byte("a"), 0o644)
	_ = os.WriteFile(tmpDataDir+"/foo/bar/b.txt", bytes.Repeat([]byte("a"), 1000), 0o644)
	_ = os.WriteFile(tmpDataDir+"/foo/c.txt", []byte("c"), 0o644)
	require.NoError(t, GenerateEmbedBindata(tmpDataDir, tmpDir+"/out.dat"))

	data, err := os.ReadFile(tmpDir + "/out.dat")
	require.NoError(t, err)
	efs := NewEmbeddedFS(data)

	// test a non-existing file
	_, err = fs.ReadFile(efs, "not exist")
	assert.ErrorIs(t, err, fs.ErrNotExist)

	// test a normal file (no compression)
	content, err := fs.ReadFile(efs, "a.txt")
	require.NoError(t, err)
	assert.Equal(t, "a", string(content))
	fi, err := fs.Stat(efs, "a.txt")
	require.NoError(t, err)
	_, ok := fi.(EmbeddedFileInfo).GetGzipContent()
	assert.False(t, ok)

	// test a compressed file
	content, err = fs.ReadFile(efs, "foo/bar/b.txt")
	require.NoError(t, err)
	assert.Equal(t, bytes.Repeat([]byte("a"), 1000), content)
	fi, err = fs.Stat(efs, "foo/bar/b.txt")
	require.NoError(t, err)
	assert.False(t, fi.Mode().IsDir())
	assert.True(t, fi.Mode().IsRegular())
	gzipContent, ok := fi.(EmbeddedFileInfo).GetGzipContent()
	assert.True(t, ok)
	assert.Greater(t, len(gzipContent), 1)
	assert.Less(t, len(gzipContent), 1000)

	// test list root directory
	entries, err := fs.ReadDir(efs, ".")
	require.NoError(t, err)
	assert.Len(t, entries, 2)
	assert.Equal(t, "a.txt", entries[0].Name())
	assert.False(t, entries[0].IsDir())

	// test list subdirectory
	entries, err = fs.ReadDir(efs, "foo")
	require.NoError(t, err)
	require.Len(t, entries, 2)
	assert.Equal(t, "bar", entries[0].Name())
	assert.True(t, entries[0].IsDir())
	assert.Equal(t, "c.txt", entries[1].Name())
	assert.False(t, entries[1].IsDir())

	// test directory mode
	fi, err = fs.Stat(efs, "foo")
	require.NoError(t, err)
	assert.True(t, fi.IsDir())
	assert.True(t, fi.Mode().IsDir())
	assert.False(t, fi.Mode().IsRegular())

	// test httpfs
	hfs := http.FS(efs)
	hf, err := hfs.Open("foo/bar/b.txt")
	require.NoError(t, err)
	hi, err := hf.Stat()
	require.NoError(t, err)
	fiEmbedded, ok := hi.(EmbeddedFileInfo)
	require.True(t, ok)
	gzipContent, ok = fiEmbedded.GetGzipContent()
	assert.True(t, ok)
	assert.Greater(t, len(gzipContent), 1)
	assert.Less(t, len(gzipContent), 1000)

	// test httpfs directory listing
	hf, err = hfs.Open("foo")
	require.NoError(t, err)
	dirs, err := hf.Readdir(1)
	require.NoError(t, err)
	assert.Len(t, dirs, 1)
}