forked from roastedroot/proxy-wasm-java-host
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTimersClocksRandomTest.java
More file actions
57 lines (43 loc) · 1.96 KB
/
TimersClocksRandomTest.java
File metadata and controls
57 lines (43 loc) · 1.96 KB
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
package io.roastedroot.proxywasm.examples;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertTrue;
import com.dylibso.chicory.wasm.Parser;
import io.roastedroot.proxywasm.ProxyWasm;
import io.roastedroot.proxywasm.StartException;
import io.roastedroot.proxywasm.WasmResult;
import java.nio.file.Path;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
import org.junit.jupiter.api.Test;
/**
* Java port of https://github.com/proxy-wasm/proxy-wasm-go-sdk/blob/ab4161dcf9246a828008b539a82a1556cf0f2e24/examples/helloworld/main_test.go
*/
public class TimersClocksRandomTest {
@Test
public void test() throws StartException {
var setTickPeriodMillisecondsCalls = new AtomicInteger(0);
var handler =
new MockHandler() {
@Override
public WasmResult setTickPeriodMilliseconds(int tick_period) {
setTickPeriodMillisecondsCalls.incrementAndGet();
return WasmResult.OK;
}
};
ProxyWasm.Builder builder = ProxyWasm.builder().withPluginHandler(handler);
var module = Parser.parse(Path.of("./src/test/go-examples/helloworld/main.wasm"));
try (var proxyWasm = builder.build(module)) {
var loggedMessages = handler.loggedMessages();
assertEquals(List.of("OnPluginStart from Go!"), loggedMessages);
loggedMessages.clear();
// the example requests tick events in the plugin start
assertEquals(1, setTickPeriodMillisecondsCalls.get());
// send it a tick.
proxyWasm.tick();
assertEquals(2, loggedMessages.size());
// This log message will look like: "It's %d: random value: %d"
assertTrue(loggedMessages.get(0).startsWith("It's "));
assertEquals("OnTick called", loggedMessages.get(1));
}
}
}