-
Notifications
You must be signed in to change notification settings - Fork 0
Meeting Records
Xinyu Li edited this page Apr 6, 2024
·
10 revisions
- Realize in the form of Tauri plugin, start with a minimal demo.
- How do we restrict users' access only to these exposed API but not to our internal commands?
- Can we allow user to do something like
import { ... } from "@deskulpt/api"
? The final resolution would be to bind the API on thewindow
global object.
- Romee:
bundler.rs
unit tests. - Yao:
config.rs
unit test. - Yao:
commands.rs
unit test (using Tauri test framework, in particular for our internal commands). - Xinyu: Widget API (after the framework is established, unit test).
-
Do we want something like Docker to be able to test on other platforms?
- Docker does not have GUI.
- Use virtual machine to test different platforms (Romee and Frank will investigate).
-
Check if the following method work for resolving React and deskulpt widget api dependency (after widget api framework pr)
Method: import map + js script
Widget code
import React from "@deskulpt/react" import { shout } from "@deskulpt/shout"
Source of dependencies
// `src/widget_dependencies/default_dependencies.js` // map `@deskulpt/react` to blob url of this script const React = window.__DESKULPT__.defaultDeps.React;
// `src/widget_dependencies/widget_api.js` // map `@deskulpt/shout` to blob url of this script async function shout(text) { try { const result = await window.__TAURI_INVOKE__( {cmd: "plugin:widget_api|shout_text", text: text } ); console.log(result); return result; } catch (error) { console.error(error); } }
Import map
<script type="importmap"> { "imports": { "@deskulpt/react": "blob:///...default_dependencies.js" "@deskulpt/widget_api": "blob:///...widget_api.js" } } </script>
- Yao: Solve #6.
- Xinyu: Format the canvas window.
- Frank: Familiarize with
React
, try to write some simple widgets. - Yao: Set up test and codecov GitHub workflows.
- Xinyu: Extend widget APIs.
We use GitHub workflow for CI and better consistency. In particular:
- We use
.github/workflows/build.yaml
to test if Deskulpt can be built on Ubuntu/Mac/Windows (this currently does not provide the actual artifact). - We use
.github/workflows/lint-core.yaml
to test if Deskulpt code pass linting checks.
Both of the above are done in two scenarios:
-
push.branch: main
, i.e., when someone pushes tomain
branch (most likely when a PR is merged intomain
) -
pull_request.branch: main
, i.e., when someone commits to a pull request that is targeted towardsmain
.
We divide into two pairs to write unit tests for two components of Deskulpt:
- Yao & Romee: bundler
- Xinyu & Frank: widget manager
Our earlier meeting records were held in Notion, but due to its storage limits we have migrated to GitHub wiki. You can check our earlier meeting records at this published Notion site.