2022-06-14 06:27:11 +00:00
|
|
|
package schema
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource/plugin"
|
2023-03-13 19:54:04 +00:00
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/testing/diagtest"
|
2023-02-17 01:23:09 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-06-14 06:27:11 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func initLoader(b *testing.B, options pluginLoaderCacheOptions) ReferenceLoader {
|
|
|
|
cwd, err := os.Getwd()
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2023-03-13 19:54:04 +00:00
|
|
|
sink := diagtest.LogSink(b)
|
2022-06-14 06:27:11 +00:00
|
|
|
ctx, err := plugin.NewContext(sink, sink, nil, nil, cwd, nil, true, nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
loader := newPluginLoaderWithOptions(ctx.Host, options)
|
|
|
|
|
|
|
|
return loader
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkLoadPackageReference(b *testing.B) {
|
|
|
|
cacheWarmingLoader := initLoader(b, pluginLoaderCacheOptions{})
|
|
|
|
// ensure the file cache exists for later tests:
|
|
|
|
_, err := cacheWarmingLoader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
|
|
|
|
b.Run("full-load", func(b *testing.B) {
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
loader := initLoader(b, pluginLoaderCacheOptions{})
|
|
|
|
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
b.Run("full-cache", func(b *testing.B) {
|
|
|
|
loader := initLoader(b, pluginLoaderCacheOptions{})
|
|
|
|
|
|
|
|
b.StopTimer()
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
b.StartTimer()
|
|
|
|
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
b.Run("mmap-cache", func(b *testing.B) {
|
|
|
|
// Disables in-memory cache (single instancing), retains mmap of files:
|
|
|
|
loader := initLoader(b, pluginLoaderCacheOptions{
|
|
|
|
disableEntryCache: true,
|
|
|
|
})
|
|
|
|
|
|
|
|
b.StopTimer()
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
b.StartTimer()
|
|
|
|
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
b.Run("file-cache", func(b *testing.B) {
|
|
|
|
// Disables in-memory cache and mmaping of files:
|
|
|
|
loader := initLoader(b, pluginLoaderCacheOptions{
|
|
|
|
disableEntryCache: true,
|
|
|
|
disableMmap: true,
|
|
|
|
})
|
|
|
|
|
|
|
|
b.StopTimer()
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
b.StartTimer()
|
|
|
|
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
b.Run("no-cache", func(b *testing.B) {
|
|
|
|
// Disables in-memory cache, mmaping, and using schema files:
|
|
|
|
loader := initLoader(b, pluginLoaderCacheOptions{
|
|
|
|
disableEntryCache: true,
|
|
|
|
disableMmap: true,
|
|
|
|
disableFileCache: true,
|
|
|
|
})
|
|
|
|
|
|
|
|
b.StopTimer()
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
b.StartTimer()
|
|
|
|
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_, err := loader.LoadPackageReference("azure-native", nil)
|
2023-02-17 01:23:09 +00:00
|
|
|
require.NoError(b, err)
|
2022-06-14 06:27:11 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|