diff options
Diffstat (limited to 'portal/test/js')
-rw-r--r-- | portal/test/js/dune | 14 | ||||
-rw-r--r-- | portal/test/js/package-lock.json | 21 | ||||
-rw-r--r-- | portal/test/js/package.json | 5 | ||||
-rw-r--r-- | portal/test/js/polyfill.js | 1 | ||||
-rw-r--r-- | portal/test/js/websockets_hello.ml | 35 |
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 |