* no camera sketch on face Signed-off-by: Jess Frazelle <github@jessfraz.com> * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix Signed-off-by: Jess Frazelle <github@jessfraz.com> * new screenshots Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix Signed-off-by: Jess Frazelle <github@jessfraz.com> * A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu) * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> * fix tests Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixes Signed-off-by: Jess Frazelle <github@jessfraz.com> * Revert "A snapshot a day keeps the bugs away! 📷🐛 (OS: ubuntu)" This reverts commite839d7101f
. * Revert "fixes" This reverts commit3df8b63e3a
. * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> --------- Signed-off-by: Jess Frazelle <github@jessfraz.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
164 lines
4.4 KiB
TypeScript
164 lines
4.4 KiB
TypeScript
import { parse, initPromise } from './wasm'
|
|
import { enginelessExecutor } from '../lib/testHelpers'
|
|
|
|
beforeAll(() => initPromise)
|
|
|
|
describe('testing artifacts', () => {
|
|
// Enable rotations #152
|
|
test('sketch artifacts', async () => {
|
|
const code = `
|
|
const mySketch001 = startSketchOn('XY')
|
|
|> startProfileAt([0, 0], %)
|
|
|> lineTo([-1.59, -1.54], %)
|
|
|> lineTo([0.46, -5.82], %)
|
|
// |> rx(45, %)
|
|
show(mySketch001)`
|
|
const programMemory = await enginelessExecutor(parse(code))
|
|
// @ts-ignore
|
|
const shown = programMemory?.return?.map(
|
|
// @ts-ignore
|
|
(a) => programMemory?.root?.[a.name]
|
|
)
|
|
expect(shown).toEqual([
|
|
{
|
|
type: 'SketchGroup',
|
|
on: expect.any(Object),
|
|
start: {
|
|
to: [0, 0],
|
|
from: [0, 0],
|
|
name: '',
|
|
__geoMeta: {
|
|
id: expect.any(String),
|
|
sourceRange: [46, 71],
|
|
},
|
|
},
|
|
value: [
|
|
{
|
|
type: 'ToPoint',
|
|
name: '',
|
|
to: [-1.59, -1.54],
|
|
from: [0, 0],
|
|
__geoMeta: {
|
|
sourceRange: [77, 102],
|
|
id: expect.any(String),
|
|
},
|
|
},
|
|
{
|
|
type: 'ToPoint',
|
|
to: [0.46, -5.82],
|
|
from: [-1.59, -1.54],
|
|
name: '',
|
|
__geoMeta: {
|
|
sourceRange: [108, 132],
|
|
id: expect.any(String),
|
|
},
|
|
},
|
|
],
|
|
position: [0, 0, 0],
|
|
rotation: [0, 0, 0, 1],
|
|
xAxis: { x: 1, y: 0, z: 0 },
|
|
yAxis: { x: 0, y: 1, z: 0 },
|
|
zAxis: { x: 0, y: 0, z: 1 },
|
|
id: expect.any(String),
|
|
entityId: expect.any(String),
|
|
__meta: [{ sourceRange: [46, 71] }],
|
|
},
|
|
])
|
|
})
|
|
test('extrude artifacts', async () => {
|
|
// Enable rotations #152
|
|
const code = `
|
|
const mySketch001 = startSketchOn('XY')
|
|
|> startProfileAt([0, 0], %)
|
|
|> lineTo([-1.59, -1.54], %)
|
|
|> lineTo([0.46, -5.82], %)
|
|
// |> rx(45, %)
|
|
|> extrude(2, %)
|
|
show(mySketch001)`
|
|
const programMemory = await enginelessExecutor(parse(code))
|
|
// @ts-ignore
|
|
const shown = programMemory?.return?.map(
|
|
// @ts-ignore
|
|
(a) => programMemory?.root?.[a.name]
|
|
)
|
|
expect(shown).toEqual([
|
|
{
|
|
type: 'ExtrudeGroup',
|
|
id: expect.any(String),
|
|
value: [],
|
|
height: 2,
|
|
position: [0, 0, 0],
|
|
rotation: [0, 0, 0, 1],
|
|
endCapId: null,
|
|
startCapId: null,
|
|
xAxis: { x: 1, y: 0, z: 0 },
|
|
yAxis: { x: 0, y: 1, z: 0 },
|
|
zAxis: { x: 0, y: 0, z: 1 },
|
|
__meta: [{ sourceRange: [46, 71] }],
|
|
},
|
|
])
|
|
})
|
|
test('sketch extrude and sketch on one of the faces', async () => {
|
|
// Enable rotations #152
|
|
// TODO #153 in order for getExtrudeWallTransform to work we need to query the engine for the location of a face.
|
|
const code = `
|
|
const sk1 = startSketchOn('XY')
|
|
|> startProfileAt([0, 0], %)
|
|
|> lineTo([-2.5, 0], %)
|
|
|> lineTo({ to: [0, 10], tag: "p" }, %)
|
|
|> lineTo([2.5, 0], %)
|
|
// |> rx(45, %)
|
|
// |> translate([1,0,1], %)
|
|
// |> ry(5, %)
|
|
const theExtrude = extrude(2, sk1)
|
|
// const theTransf = getExtrudeWallTransform('p', theExtrude)
|
|
const sk2 = startSketchOn('XY')
|
|
|> startProfileAt([0, 0], %)
|
|
|> lineTo([-2.5, 0], %)
|
|
|> lineTo({ to: [0, 3], tag: "p" }, %)
|
|
|> lineTo([2.5, 0], %)
|
|
// |> transform(theTransf, %)
|
|
|> extrude(2, %)
|
|
|
|
|
|
show(theExtrude, sk2)`
|
|
const programMemory = await enginelessExecutor(parse(code))
|
|
// @ts-ignore
|
|
const geos = programMemory?.return?.map(
|
|
// @ts-ignore
|
|
({ name }) => programMemory?.root?.[name]
|
|
)
|
|
expect(geos).toEqual([
|
|
{
|
|
type: 'ExtrudeGroup',
|
|
id: expect.any(String),
|
|
value: [],
|
|
height: 2,
|
|
position: [0, 0, 0],
|
|
rotation: [0, 0, 0, 1],
|
|
endCapId: null,
|
|
startCapId: null,
|
|
xAxis: { x: 1, y: 0, z: 0 },
|
|
yAxis: { x: 0, y: 1, z: 0 },
|
|
zAxis: { x: 0, y: 0, z: 1 },
|
|
__meta: [{ sourceRange: [38, 63] }],
|
|
},
|
|
{
|
|
type: 'ExtrudeGroup',
|
|
id: expect.any(String),
|
|
value: [],
|
|
height: 2,
|
|
position: [0, 0, 0],
|
|
rotation: [0, 0, 0, 1],
|
|
|
|
endCapId: null,
|
|
startCapId: null,
|
|
xAxis: { x: 1, y: 0, z: 0 },
|
|
yAxis: { x: 0, y: 1, z: 0 },
|
|
zAxis: { x: 0, y: 0, z: 1 },
|
|
__meta: [{ sourceRange: [356, 381] }],
|
|
},
|
|
])
|
|
})
|
|
})
|