data:image/s3,"s3://crabby-images/6d999/6d999cffd55e8d0f872810077c1db10abd5c774a" alt="Graham_Vasquez Graham_Vasquez"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 03, 2020 11:24 AM
Hi, I am working on a custom block and would like to automate my deployments. I want to write some tests for it, but I haven’t had any success with this as of yet.
Any ideas for how this can be done?
data:image/s3,"s3://crabby-images/01286/01286a649018134e03940cdaad71ebfcba46f4d9" alt="Matthew_Thomas Matthew_Thomas"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 05, 2020 05:56 AM
Welcome to the community @Graham_Vasquez!
There are a bunch of testing frameworks you can use for custom blocks. I believe the Airtable team uses Jest for their testing, and is one I’ve been using myself. The site has great documentation for how to get started, but in a nutshell, the first steps you would need to take are:
- Install Jest (or whatever test package you want)
- Write a test file, called myBlock.test.js (if using Jest, I believe all files need to end with
.test.js
for them to be found). - Run Jest. If you’re in the directory with your custom block, typing
jest
should do the trick. If usingnpm
, you can also add custom flags to a script and then runnpm test
.
Another popular unit testing package for Javascript is Mocha, but I think Jest was designed more closely with React in mind.
If this answers your question, please consider marking it as “solution”. If not, I’m happy to work with you further. Thanks!
data:image/s3,"s3://crabby-images/6d999/6d999cffd55e8d0f872810077c1db10abd5c774a" alt="Graham_Vasquez Graham_Vasquez"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 06, 2020 01:54 PM
Hi Matt,
Thanks for the guidance. I am running into a bit of an issue in that when I try to run the tests it always fails giving me the following error:
@airtable/blocks can only run inside the block frame
Any thoughts on how I can test the Airtable functions with my tests?
Thanks :slightly_smiling_face:
data:image/s3,"s3://crabby-images/01286/01286a649018134e03940cdaad71ebfcba46f4d9" alt="Matthew_Thomas Matthew_Thomas"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 08, 2020 04:13 AM
Ah, I see, this now looks a lot more limiting than I originally thought. I haven’t seen anything in the documentation or the community (yet) to indicate that this “offline” approach with Jest, or other similar package, would be possible for your Airtable-specific function code.
The next route I might suggest is a little more convoluted and not as nice, but should get the job done? You could build a debug/test mode into your custom block (e.g. a “Run tests” button) that appears only while you’re developing the block. This block could then iterate over any tests you’ve written, and since running within the Block itself, should have access to the Airtable functions.
Tests could be written much the same way, though probably needing plain Javascript, instead of Jest/other testing framework code. Keep tests in separate *.test.js
files that you then import into the helper function that runs the tests (i.e. just calling each test function sequentially).
data:image/s3,"s3://crabby-images/0d351/0d351990236b19663f8e4f96a107c5acecffe0d1" alt="Kasra Kasra"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 08, 2020 11:54 AM
We’re still exploring the best way to test blocks. A few ideas:
- A “test mode” inside your block, as @Matthew_Thomas suggests.
- Write the block in a way that lets you write unit tests for the logic separate from the blocks environment. For example, a timeline block may have a
layout
function that takesArray<{recordId, startDate, endDate}>
and returns information about how to lay out those items e.g.Array<{recordId, x, y}>
. You could write unit tests for this. - End-to-end tests with something like https://www.selenium.dev or https://www.cypress.io. In this case the block would need to be released in a live base. You could use remotes to create a separate test base.
data:image/s3,"s3://crabby-images/f847e/f847efabff59432f63d1cf1a2cde0b29210bf891" alt="Hypha_Worker_Co Hypha_Worker_Co"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Nov 05, 2020 08:08 AM
I haven’t yet done this myself, but ran into a similar concern with testing an app using specialized hooks. (I’m assuming it’s the hooks and their expected context that is giving you trouble.)
import { useHook } from 'some-lib'
const MyComponent = ({ foo, useSomeHook = useSome }) => {
const { bar, baz } = useSomeHook()
return (
<div
)
}
Then you kinda ignore it in your actual app code, but when doing testing or using storybookJS to isolate key states, you inject a fake mock hook that spits out whatever values you want to exercise :slightly_smiling_face:
Hopefully this is helpful!
data:image/s3,"s3://crabby-images/8cb2f/8cb2f3bec7aa3b8b55da0b6eb8d1d81194430375" alt=""