|
30 | 30 | namespace proxy_wasm {
|
31 | 31 | namespace {
|
32 | 32 |
|
33 |
| -INSTANTIATE_TEST_SUITE_P(WasmEngines, TestVM, testing::ValuesIn(getWasmEngines()), |
| 33 | +INSTANTIATE_TEST_SUITE_P(WasmEngines, TestVm, testing::ValuesIn(getWasmEngines()), |
34 | 34 | [](const testing::TestParamInfo<std::string> &info) {
|
35 | 35 | return info.param;
|
36 | 36 | });
|
37 | 37 |
|
38 |
| -class TestContext : public ContextBase { |
39 |
| -public: |
40 |
| - TestContext(WasmBase *base) : ContextBase(base){}; |
41 |
| - WasmResult log(uint32_t /*log_level*/, std::string_view msg) override { |
42 |
| - log_ += std::string(msg) + "\n"; |
43 |
| - return WasmResult::Ok; |
44 |
| - } |
45 |
| - std::string &log_msg() { return log_; } |
46 |
| - |
47 |
| -private: |
48 |
| - std::string log_; |
49 |
| -}; |
50 |
| - |
51 |
| -TEST_P(TestVM, Environment) { |
| 38 | +TEST_P(TestVm, Environment) { |
52 | 39 | std::unordered_map<std::string, std::string> envs = {{"KEY1", "VALUE1"}, {"KEY2", "VALUE2"}};
|
53 | 40 | auto source = readTestWasmFile("env.wasm");
|
54 |
| - |
55 |
| - auto wasm_base = WasmBase(std::move(vm_), "vm_id", "", "", envs, {}); |
56 |
| - ASSERT_TRUE(wasm_base.wasm_vm()->load(source, {}, {})); |
57 |
| - |
58 |
| - TestContext context(&wasm_base); |
59 |
| - current_context_ = &context; |
60 |
| - |
61 |
| - wasm_base.registerCallbacks(); |
62 |
| - |
63 |
| - ASSERT_TRUE(wasm_base.wasm_vm()->link("")); |
| 41 | + ASSERT_FALSE(source.empty()); |
| 42 | + auto wasm = TestWasm(std::move(vm_), envs); |
| 43 | + ASSERT_TRUE(wasm.load(source, false)); |
| 44 | + ASSERT_TRUE(wasm.initialize()); |
64 | 45 |
|
65 | 46 | WasmCallVoid<0> run;
|
66 |
| - wasm_base.wasm_vm()->getFunction("run", &run); |
67 |
| - |
68 |
| - run(current_context_); |
69 |
| - |
70 |
| - auto msg = context.log_msg(); |
71 |
| - EXPECT_NE(std::string::npos, msg.find("KEY1: VALUE1\n")) << msg; |
72 |
| - EXPECT_NE(std::string::npos, msg.find("KEY2: VALUE2\n")) << msg; |
| 47 | + wasm.wasm_vm()->getFunction("run", &run); |
| 48 | + ASSERT_TRUE(run != nullptr); |
| 49 | + run(wasm.vm_context()); |
| 50 | + |
| 51 | + // Check application logs. |
| 52 | + auto *context = dynamic_cast<TestContext *>(wasm.vm_context()); |
| 53 | + EXPECT_TRUE(context->isLogged("KEY1: VALUE1\n")); |
| 54 | + EXPECT_TRUE(context->isLogged("KEY2: VALUE2\n")); |
73 | 55 | }
|
74 | 56 |
|
75 |
| -TEST_P(TestVM, WithoutEnvironment) { |
| 57 | +TEST_P(TestVm, WithoutEnvironment) { |
76 | 58 | auto source = readTestWasmFile("env.wasm");
|
77 |
| - auto wasm_base = WasmBase(std::move(vm_), "vm_id", "", "", {}, {}); |
78 |
| - ASSERT_TRUE(wasm_base.wasm_vm()->load(source, {}, {})); |
79 |
| - |
80 |
| - TestContext context(&wasm_base); |
81 |
| - current_context_ = &context; |
82 |
| - |
83 |
| - wasm_base.registerCallbacks(); |
84 |
| - |
85 |
| - ASSERT_TRUE(wasm_base.wasm_vm()->link("")); |
| 59 | + ASSERT_FALSE(source.empty()); |
| 60 | + auto wasm = TestWasm(std::move(vm_), {}); |
| 61 | + ASSERT_TRUE(wasm.load(source, false)); |
| 62 | + ASSERT_TRUE(wasm.initialize()); |
86 | 63 |
|
87 | 64 | WasmCallVoid<0> run;
|
88 |
| - wasm_base.wasm_vm()->getFunction("run", &run); |
89 |
| - |
90 |
| - run(current_context_); |
| 65 | + wasm.wasm_vm()->getFunction("run", &run); |
| 66 | + ASSERT_TRUE(run != nullptr); |
| 67 | + run(wasm.vm_context()); |
91 | 68 |
|
92 |
| - EXPECT_EQ(context.log_msg(), ""); |
| 69 | + // Check application logs. |
| 70 | + auto *context = dynamic_cast<TestContext *>(wasm.vm_context()); |
| 71 | + EXPECT_TRUE(context->isLogEmpty()); |
93 | 72 | }
|
94 | 73 |
|
95 |
| -TEST_P(TestVM, Clock) { |
| 74 | +TEST_P(TestVm, Clock) { |
96 | 75 | auto source = readTestWasmFile("clock.wasm");
|
97 |
| - auto wasm_base = WasmBase(std::move(vm_), "vm_id", "", "", {}, {}); |
98 |
| - ASSERT_TRUE(wasm_base.wasm_vm()->load(source, {}, {})); |
99 |
| - |
100 |
| - TestContext context(&wasm_base); |
101 |
| - current_context_ = &context; |
102 |
| - |
103 |
| - wasm_base.registerCallbacks(); |
104 |
| - |
105 |
| - ASSERT_TRUE(wasm_base.wasm_vm()->link("")); |
| 76 | + ASSERT_FALSE(source.empty()); |
| 77 | + auto wasm = TestWasm(std::move(vm_)); |
| 78 | + ASSERT_TRUE(wasm.load(source, false)); |
| 79 | + ASSERT_TRUE(wasm.initialize()); |
106 | 80 |
|
107 | 81 | WasmCallVoid<0> run;
|
108 |
| - wasm_base.wasm_vm()->getFunction("run", &run); |
109 |
| - ASSERT_TRUE(run); |
110 |
| - run(current_context_); |
111 |
| - |
112 |
| - // Check logs. |
113 |
| - auto msg = context.log_msg(); |
114 |
| - EXPECT_NE(std::string::npos, msg.find("monotonic: ")) << msg; |
115 |
| - EXPECT_NE(std::string::npos, msg.find("realtime: ")) << msg; |
| 82 | + wasm.wasm_vm()->getFunction("run", &run); |
| 83 | + ASSERT_TRUE(run != nullptr); |
| 84 | + run(wasm.vm_context()); |
| 85 | + |
| 86 | + // Check application logs. |
| 87 | + auto *context = dynamic_cast<TestContext *>(wasm.vm_context()); |
| 88 | + EXPECT_TRUE(context->isLogged("monotonic: ")); |
| 89 | + EXPECT_TRUE(context->isLogged("realtime: ")); |
116 | 90 | }
|
117 | 91 |
|
118 | 92 | } // namespace
|
|
0 commit comments