Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[x/programs] add program abstraction #660

Merged
merged 29 commits into from
Jan 7, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
c71e603
Move fixtures into tests directory
hexfusion Dec 14, 2023
903fefe
Abstract engine from runtime
hexfusion Dec 14, 2023
ff0adb6
React to changes
hexfusion Dec 14, 2023
cea5ea5
Nits
hexfusion Dec 15, 2023
f25a144
Review comments
hexfusion Dec 21, 2023
29d3bbe
Clarify debug mode
hexfusion Dec 21, 2023
a75af73
Nit
hexfusion Dec 21, 2023
3d03b4c
Add host abstraction
hexfusion Dec 15, 2023
2b7ba48
React to changes
hexfusion Dec 15, 2023
3ac1a3f
Cleanup
hexfusion Dec 21, 2023
195c96a
Move program from runtime
hexfusion Dec 22, 2023
af1201b
Add program abstraction
hexfusion Dec 22, 2023
597ff1a
Implement runtime instance and react to changes
hexfusion Dec 22, 2023
2fbdc8e
Nit
hexfusion Dec 22, 2023
fa5565d
Add RegisterImportWrapFn
hexfusion Dec 22, 2023
7485e7c
Update examples
hexfusion Dec 22, 2023
e1bbfc4
Show example of wrap import function impl
hexfusion Dec 22, 2023
8dbe3ed
Remove stale docs
hexfusion Dec 22, 2023
678a8cb
Impliment pstate with wrap functionality
hexfusion Dec 22, 2023
7e5f311
license header lint
samliok Dec 27, 2023
95aa598
remove hardcoded wrapper funcitons, fixed pstate bugs
samliok Jan 6, 2024
13ff0a6
lint
samliok Jan 6, 2024
cee952c
lint
samliok Jan 6, 2024
5c359d9
Merge branch 'dynamic_args' into refactor-statekey
samliok Jan 6, 2024
15b84b5
Revert "Merge branch 'dynamic_args' into refactor-statekey"
samliok Jan 6, 2024
3a23ebb
Revert "Revert "Merge branch 'dynamic_args' into refactor-statekey""
samliok Jan 6, 2024
7f323b2
lint
samliok Jan 6, 2024
b5e64fb
memory tests
samliok Jan 6, 2024
d175d2c
create WAT program instead of memory.wasm
samliok Jan 6, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
memory tests
  • Loading branch information
samliok committed Jan 6, 2024
commit b5e64fb3bb4938de94e4410022033f46c2880cec
3 changes: 1 addition & 2 deletions x/programs/program/memory_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ func TestMemory(t *testing.T) {

func newTestMemory(t *testing.T) *Memory {
require := require.New(t)
wasmBytes := tests.ReadFixture(t, "../tests/fixture/token.wasm")
wasmBytes := tests.ReadFixture(t, "../tests/fixture/memory.wasm")

// create new instance
eng := engine.New(engine.NewConfig())
Expand All @@ -53,7 +53,6 @@ func newTestMemory(t *testing.T) *Memory {
require.NoError(err)
inst, err := wasmtime.NewInstance(store.Get(), mod, nil)
require.NoError(err)

// get alloc export func
alloc := inst.GetExport(store.Get(), AllocFnName)
require.NotNil(alloc)
Expand Down
42 changes: 12 additions & 30 deletions x/programs/runtime/runtime_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import (
"github.com/ava-labs/hypersdk/x/programs/engine"
"github.com/ava-labs/hypersdk/x/programs/host"
"github.com/ava-labs/hypersdk/x/programs/program"
"github.com/ava-labs/hypersdk/x/programs/tests"
)

func TestStop(t *testing.T) {
Expand Down Expand Up @@ -211,51 +212,32 @@ func TestLimitMaxMemory(t *testing.T) {
func TestLimitMaxMemoryGrow(t *testing.T) {
require := require.New(t)

wasm, err := wasmtime.Wat2Wasm(`
(module

(memory 1) ;; 1 pages
(export "memory" (memory 0))
)
`)
require.NoError(err)

wasm := tests.ReadFixture(t, "../tests/fixture/memory.wasm")
maxUnits := uint64(1)
cfg := NewConfig().SetLimitMaxMemory(1 * program.MemoryPageSize)
require.NoError(err)
cfg := NewConfig().SetLimitMaxMemory(18 * program.MemoryPageSize)
eng := engine.New(engine.NewConfig())
runtime := New(logging.NoLog{}, eng, host.NoSupportedImports, cfg)
err = runtime.Initialize(context.Background(), wasm, maxUnits)
err := runtime.Initialize(context.Background(), wasm, maxUnits)
require.NoError(err)

mem, err := runtime.Memory()
require.NoError(err)
length, err := mem.Len()
require.NoError(err)
require.Equal(uint64(0x10000), length)

// attempt to grow memory to 2 pages which exceeds the limit
_, err = mem.Grow(1)
require.ErrorContains(err, "failed to grow memory by `1`")
// default memory is 18 pages
_, err = mem.Grow(17)
require.ErrorContains(err, "failed to grow memory by `17`")
}

func TestWriteExceedsLimitMaxMemory(t *testing.T) {
require := require.New(t)

wasm, err := wasmtime.Wat2Wasm(`
(module

(memory 1) ;; 1 pages
(export "memory" (memory 0))
)
`)
require.NoError(err)
wasm := tests.ReadFixture(t, "../tests/fixture/memory.wasm")

maxUnits := uint64(1)
cfg := NewConfig().SetLimitMaxMemory(1 * program.MemoryPageSize)
cfg := NewConfig()
eng := engine.New(engine.NewConfig())
runtime := New(logging.NoLog{}, eng, host.NoSupportedImports, cfg)
err = runtime.Initialize(context.Background(), wasm, maxUnits)
err := runtime.Initialize(context.Background(), wasm, maxUnits)
require.NoError(err)
mem, err := runtime.Memory()
require.NoError(err)
Expand All @@ -277,13 +259,13 @@ func TestWithMaxWasmStack(t *testing.T) {
(local i32)
i32.const 1
)
)
)
`)
require.NoError(err)

maxUnits := uint64(4)
ecfg, err := engine.NewConfigBuilder().
WithMaxWasmStack(720).
WithMaxWasmStack(1000).
Build()
require.NoError(err)
eng := engine.New(ecfg)
Expand Down
Binary file added x/programs/tests/fixture/memory.wasm
Binary file not shown.
Loading