-
Notifications
You must be signed in to change notification settings - Fork 2
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
Setup Wasm test case #4
base: dev
Are you sure you want to change the base?
Conversation
@@ -1,6 +1,6 @@ | |||
# Overview | |||
|
|||
This folder contains the sysroot for the openvela Wasm Application Framework. | |||
This folder contains the sysroot for the Vela Wasm Application Framework. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should we keep openvela here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
please update the patch, use openvela instead
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok
# limitations under the License. | ||
# | ||
|
||
CONFIGURED_APPS += $(APPDIR)/frameworks/runtimes/wasm/test |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should we add ifneq/endif
* `libc`: The C standard library for Wasm | ||
* `memory`: Memory aceess management between wasm and native code | ||
* `test`: Unit test cases for each module | ||
* `vela-sysroot`: A collection of extra header files to build WebAssembly applications |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
let's creae a new patch to change vela-sysroot to sysroot
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok
* `chre`: 该模块提供了从 Context Hub Runtime Environment 到 Wasm 运行时的功能 | ||
* `libc`: 用于 Wasm 的 C 标准库 | ||
* `memory`: Wasm 和原生代码之间的内存访问管理 | ||
* `vela-sysroot`: 用于构建 WebAssembly 应用程序的额外头文件集合 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ditto
@HoTBAIzZY did these patch already merged into gerrit? |
yes |
Summary
Added new test module with initial test cases for libc functions in WASM: Implemented test cases for string.h functions (strlen, strcmp, strcpy) and stdlib.h functions (malloc, free, atoi).
Modified the test suite to only run WebAssembly (WASM) tests when WAMR is enabled: This change prevents WASM-related test failures in environments where WAMR is not available or not desired, making the test suite more robust and configurable.
Added missing key-value database (KVDB) interface implementation to the WebAssembly frameworks layer: This enables WASM applications to access persistent key-value storage functionality, improving feature parity between native and WASM environments.
Removed CONFIG_INTERPRETERS_WAMR_EXTERNAL_MODULE_REGISTRY: This simplifies the build configuration.
Impact
Enables automated testing of core libc functionality: Provides regression testing for critical system functions and improves code quality through test coverage.
Prevents WASM-related test failures in non-WAMR environments: Makes the test suite more robust and configurable.
Enables WASM applications to use KVDB operations: Improves feature parity between native and WASM environments and enables persistent storage use cases in WASM applications.
Simplifies the build configuration: Removes unnecessary complexity by eliminating CONFIG_INTERPRETERS_WAMR_EXTERNAL_MODULE_REGISTRY.
Testing
CI integration added to run tests on every commit: Ensures continuous validation of the codebase.
Verified tests pass when WAMR is enabled: Confirmed that WASM tests are skipped when WAMR is disabled, and ran the full test suite to ensure no regressions in other tests.
Added unit tests for all new KVDB interface methods: Verified KVDB operations work in the WASM runtime and tested with a sample WASM application using KVDB.
Ensured no regressions in existing test suite: Ran the full test suite to confirm stability after changes.