What
I quickly wrote an app that lets users paint on an HTML5 canvas together.
data:image/s3,"s3://crabby-images/c25e2/c25e2a159ff122dc536794b75dc8392cf5967f32" alt=""
Puppeteer is used to simulate headless browser users (instead of direct API calls).
data:image/s3,"s3://crabby-images/1a1b5/1a1b5552ae5fe049c34e1ea9e0f027602932a65d" alt=""
If you’ve read any of my gRPC with Typescript and Go posts, you’ll be familiar with the tech – it’s an RPC service with two methods
...
service DrawService {
rpc SendDrawing(Drawing) returns (None);
rpc GetDrawings(None) returns (stream Drawings) {}
}
...
Right now, Puppeteer simulates a single user. I’m surprised at how little code is needed to do headless browser testing!
import * as puppeteer from 'puppeteer';
function sleep (time) {
return new Promise((resolve) => setTimeout(resolve, time));
}
(async () => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.goto('http://localhost:3000');
console.log("Looping on move...");
for (let i = 0; i < 1000; i++) {
await page.mouse.move(Math.random() * 500, Math.random() * 500);
await sleep(100);
}
console.log("Looping on move...done");
await browser.close();
})();
The source is here.
Why
For fun most of all – I love the HTML5 canvas.
But also because we’ll need some “real” code for upcoming blog posts.
This is a reminder about how hard session management is. I’ve made a couple1 sins2 just to be done in an afternoon. Even languages like Go let you compile a gun to shoot yourself in the foot with.
Stay tuned!