aboutsummaryrefslogtreecommitdiff
path: root/portal/test/js
diff options
context:
space:
mode:
Diffstat (limited to 'portal/test/js')
-rw-r--r--portal/test/js/dune14
-rw-r--r--portal/test/js/package-lock.json21
-rw-r--r--portal/test/js/package.json5
-rw-r--r--portal/test/js/polyfill.js1
-rw-r--r--portal/test/js/websockets_hello.ml35
5 files changed, 76 insertions, 0 deletions
diff --git a/portal/test/js/dune b/portal/test/js/dune
new file mode 100644
index 0000000..b34c980
--- /dev/null
+++ b/portal/test/js/dune
@@ -0,0 +1,14 @@
+(test
+ (name websockets_hello)
+ (libraries portal_ws lwt js_of_ocaml)
+ (modes js)
+ (preprocess (pps js_of_ocaml-ppx))
+ (deps node_modules)
+ (js_of_ocaml
+ (javascript_files polyfill.js)))
+
+(rule
+ (alias npm)
+ (target node_modules)
+ (deps package.json package-lock.json)
+ (action (system "npm ci")))
diff --git a/portal/test/js/package-lock.json b/portal/test/js/package-lock.json
new file mode 100644
index 0000000..8b5d148
--- /dev/null
+++ b/portal/test/js/package-lock.json
@@ -0,0 +1,21 @@
+{
+ "name": "js",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "dependencies": {
+ "xmlhttprequest": "^1.8.0"
+ }
+ },
+ "node_modules/xmlhttprequest": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz",
+ "integrity": "sha512-58Im/U0mlVBLM38NdZjHyhuMtCqa61469k2YP/AaPbvCoV9aQGUpbJBj1QRm2ytRiVQBD/fsw7L2bJGDVQswBA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ }
+ }
+}
diff --git a/portal/test/js/package.json b/portal/test/js/package.json
new file mode 100644
index 0000000..3b36bf4
--- /dev/null
+++ b/portal/test/js/package.json
@@ -0,0 +1,5 @@
+{
+ "dependencies": {
+ "xmlhttprequest": "^1.8.0"
+ }
+}
diff --git a/portal/test/js/polyfill.js b/portal/test/js/polyfill.js
new file mode 100644
index 0000000..e394ec8
--- /dev/null
+++ b/portal/test/js/polyfill.js
@@ -0,0 +1 @@
+global.XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
diff --git a/portal/test/js/websockets_hello.ml b/portal/test/js/websockets_hello.ml
new file mode 100644
index 0000000..fa47965
--- /dev/null
+++ b/portal/test/js/websockets_hello.ml
@@ -0,0 +1,35 @@
+open Lwt.Syntax
+open Js_of_ocaml
+
+(* https://stackoverflow.com/questions/34929382/what-are-the-differences-between-lwt-async-and-lwt-main-run-on-ocaml-node-js *)
+let rec run t =
+ let next_tick (_callback : unit -> unit) =
+ Js.Unsafe.(fun_call
+ (js_expr "process.nextTick")
+ [| inject (Js.wrap_callback _callback) |])
+ in Lwt.wakeup_paused ();
+ match Lwt.poll t with
+ | Some x -> x
+ | None ->
+ if Lwt.paused_count () > 0
+ then next_tick (fun () -> run t)
+ else ()
+
+let () =
+ run @@
+ let* server = Portal_ws.ws_endpoint "telepath.im" in
+ let stream, push =
+ (* Echo is a websocket that... echoes you stuff. *)
+ Portal_ws.ws_stream "wss://echo.websocket.org" in
+ push (Some "great text");
+ push (Some "other text");
+ push (Some "yet another text");
+ push (Some "BYE");
+ let+ _ = Lwt_stream.iter
+ (fun greetings ->
+ match greetings with
+ (* When the websocket sends "BYE", we close. *)
+ | "BYE" -> print_endline "CLOSING BYE"; push None
+ | hello -> print_endline ("> " ^ hello))
+ stream
+ in print_endline server