Compare commits
	
		
			1 Commits
		
	
	
		
			kcl-0.2.21
			...
			kurt-test-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| ab5b83bbce | 
| @ -2,9 +2,7 @@ NODE_ENV=development | |||||||
| DEV=true | DEV=true | ||||||
| VITE_KC_API_WS_MODELING_URL=wss://api.dev.zoo.dev/ws/modeling/commands | VITE_KC_API_WS_MODELING_URL=wss://api.dev.zoo.dev/ws/modeling/commands | ||||||
| VITE_KC_API_BASE_URL=https://api.dev.zoo.dev | VITE_KC_API_BASE_URL=https://api.dev.zoo.dev | ||||||
| BASE_URL=https://api.dev.zoo.dev |  | ||||||
| VITE_KC_SITE_BASE_URL=https://dev.zoo.dev | VITE_KC_SITE_BASE_URL=https://dev.zoo.dev | ||||||
| VITE_KC_SKIP_AUTH=false | VITE_KC_SKIP_AUTH=false | ||||||
| VITE_KC_CONNECTION_TIMEOUT_MS=5000 | VITE_KC_CONNECTION_TIMEOUT_MS=5000 | ||||||
| # ONLY add your token in .env.development.local if you want to skip auth, otherwise this token takes precedence! | VITE_KC_DEV_TOKEN="your token from dev.zoo.dev should go in .env.development.local" | ||||||
| #VITE_KC_DEV_TOKEN="your token from dev.zoo.dev should go in .env.development.local" |  | ||||||
|  | |||||||
| @ -1,3 +1,2 @@ | |||||||
| src/wasm-lib/* | src/wasm-lib/* | ||||||
| *.typegen.ts | *.typegen.ts | ||||||
| packages/codemirror-lsp-client/dist/* |  | ||||||
|  | |||||||
| @ -13,8 +13,6 @@ | |||||||
|       "plugin:css-modules/recommended" |       "plugin:css-modules/recommended" | ||||||
|     ], |     ], | ||||||
|     "rules": { |     "rules": { | ||||||
|       "@typescript-eslint/no-floating-promises": "error", |  | ||||||
|       "@typescript-eslint/no-misused-promises": "error", |  | ||||||
|       "semi": [ |       "semi": [ | ||||||
|         "error", |         "error", | ||||||
|         "never" |         "never" | ||||||
| @ -26,6 +24,7 @@ | |||||||
|       { |       { | ||||||
|         "files": ["e2e/**/*.ts"], // Update the pattern based on your file structure |         "files": ["e2e/**/*.ts"], // Update the pattern based on your file structure | ||||||
|         "rules": { |         "rules": { | ||||||
|  |           "@typescript-eslint/no-floating-promises": "warn", | ||||||
|           "suggest-no-throw/suggest-no-throw": "off", |           "suggest-no-throw/suggest-no-throw": "off", | ||||||
|           "testing-library/prefer-screen-queries": "off", |           "testing-library/prefer-screen-queries": "off", | ||||||
|           "jest/valid-expect": "off" |           "jest/valid-expect": "off" | ||||||
|  | |||||||
| @ -1,59 +0,0 @@ | |||||||
| # bash strict mode |  | ||||||
| set -euo pipefail |  | ||||||
|  |  | ||||||
| if [[ ! -f "test-results/.last-run.json" ]]; then |  | ||||||
|     # if no last run artifact, than run plawright normally |  | ||||||
|     echo "run playwright normally" |  | ||||||
|     if [[ "$3" == "ubuntu-latest" ]]; then |  | ||||||
|         yarn test:playwright:browser:chrome:ubuntu -- --shard=$1/$2 || true |  | ||||||
|     elif [[ "$3" == "windows-latest" ]]; then |  | ||||||
|         yarn test:playwright:browser:chrome:windows -- --shard=$1/$2 || true |  | ||||||
|     else |  | ||||||
|         echo "Do not run playwright. Unable to detect os runtime." |  | ||||||
|         exit 1 |  | ||||||
|     fi |  | ||||||
|     # # send to axiom |  | ||||||
|     node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| retry=1 |  | ||||||
| max_retrys=4 |  | ||||||
|  |  | ||||||
| # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues |  | ||||||
| while [[ $retry -le $max_retrys ]]; do |  | ||||||
|     if [[ -f "test-results/.last-run.json" ]]; then |  | ||||||
|         failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) |  | ||||||
|         if [[ $failed_tests -gt 0 ]]; then |  | ||||||
|             echo "retried=true" >>$GITHUB_OUTPUT |  | ||||||
|             echo "run playwright with last failed tests and retry $retry" |  | ||||||
|             if [[ "$3" == "ubuntu-latest" ]]; then |  | ||||||
|                 yarn test:playwright:browser:chrome:ubuntu -- --last-failed || true |  | ||||||
|             elif [[ "$3" == "windows-latest" ]]; then |  | ||||||
|                 yarn test:playwright:browser:chrome:windows -- --last-failed || true |  | ||||||
|             else |  | ||||||
|                 echo "Do not run playwright. Unable to detect os runtime." |  | ||||||
|                 exit 1 |  | ||||||
|             fi |  | ||||||
|             # send to axiom |  | ||||||
|             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 |  | ||||||
|             retry=$((retry + 1)) |  | ||||||
|         else |  | ||||||
|             echo "retried=false" >>$GITHUB_OUTPUT |  | ||||||
|             exit 0 |  | ||||||
|         fi |  | ||||||
|     else |  | ||||||
|         echo "retried=false" >>$GITHUB_OUTPUT |  | ||||||
|         exit 0 |  | ||||||
|     fi |  | ||||||
| done |  | ||||||
|  |  | ||||||
| echo "retried=false" >>$GITHUB_OUTPUT |  | ||||||
|  |  | ||||||
| if [[ -f "test-results/.last-run.json" ]]; then |  | ||||||
|     failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) |  | ||||||
|     if [[ $failed_tests -gt 0 ]]; then |  | ||||||
|         # if it still fails after 3 retrys, then fail the job |  | ||||||
|         exit 1 |  | ||||||
|     fi |  | ||||||
| fi |  | ||||||
| exit 0 |  | ||||||
							
								
								
									
										63
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										63
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							| @ -1,63 +0,0 @@ | |||||||
| # bash strict mode |  | ||||||
| set -euo pipefail |  | ||||||
|  |  | ||||||
| if [[ ! -f "test-results/.last-run.json" ]]; then |  | ||||||
|     # if no last run artifact, than run plawright normally |  | ||||||
|     echo "run playwright normally" |  | ||||||
|         if [[ "$1" == "ubuntu-latest" ]]; then |  | ||||||
|             xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu || true |  | ||||||
|         elif [[ "$1" == "windows-latest" ]]; then |  | ||||||
|             yarn test:playwright:electron:windows || true |  | ||||||
|         elif [[ "$1" == "macos-14" ]]; then |  | ||||||
|             yarn test:playwright:electron:macos || true |  | ||||||
|         else |  | ||||||
|             echo "Do not run playwright. Unable to detect os runtime." |  | ||||||
|             exit 1 |  | ||||||
|         fi |  | ||||||
|         # # send to axiom |  | ||||||
|         node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| retry=1 |  | ||||||
| max_retrys=4 |  | ||||||
|  |  | ||||||
| # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues |  | ||||||
| while [[ $retry -le $max_retrys ]]; do |  | ||||||
|     if [[ -f "test-results/.last-run.json" ]]; then |  | ||||||
|         failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) |  | ||||||
|         if [[ $failed_tests -gt 0 ]]; then |  | ||||||
|             echo "retried=true" >>$GITHUB_OUTPUT |  | ||||||
|             echo "run playwright with last failed tests and retry $retry" |  | ||||||
|             if [[ "$1" == "ubuntu-latest" ]]; then |  | ||||||
|                 xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu -- --last-failed || true |  | ||||||
|             elif [[ "$1" == "windows-latest" ]]; then |  | ||||||
|                 yarn test:playwright:electron:windows -- --last-failed || true |  | ||||||
|             elif [[ "$1" == "macos-14" ]]; then |  | ||||||
|                 yarn test:playwright:electron:macos -- --last-failed || true |  | ||||||
|             else |  | ||||||
|                 echo "Do not run playwright. Unable to detect os runtime." |  | ||||||
|                 exit 1 |  | ||||||
|             fi |  | ||||||
|             # send to axiom |  | ||||||
|             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 |  | ||||||
|             retry=$((retry + 1)) |  | ||||||
|         else |  | ||||||
|             echo "retried=false" >>$GITHUB_OUTPUT |  | ||||||
|             exit 0 |  | ||||||
|         fi |  | ||||||
|     else |  | ||||||
|         echo "retried=false" >>$GITHUB_OUTPUT |  | ||||||
|         exit 0 |  | ||||||
|     fi |  | ||||||
| done |  | ||||||
|  |  | ||||||
| echo "retried=false" >>$GITHUB_OUTPUT |  | ||||||
|  |  | ||||||
| if [[ -f "test-results/.last-run.json" ]]; then |  | ||||||
|     failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) |  | ||||||
|     if [[ $failed_tests -gt 0 ]]; then |  | ||||||
|         # if it still fails after 3 retrys, then fail the job |  | ||||||
|         exit 1 |  | ||||||
|     fi |  | ||||||
| fi |  | ||||||
| exit 0 |  | ||||||
							
								
								
									
										379
									
								
								.github/workflows/build-test-publish-apps.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										379
									
								
								.github/workflows/build-test-publish-apps.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,4 +1,4 @@ | |||||||
| name: build-publish-apps | name: build-test-publish-apps | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   pull_request: |   pull_request: | ||||||
| @ -21,11 +21,10 @@ concurrency: | |||||||
|   cancel-in-progress: true |   cancel-in-progress: true | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   prepare-files: |   prepare-json-files: | ||||||
|     runs-on: ubuntu-22.04  # seperate job on Ubuntu for easy string manipulations (compared to Windows) |     runs-on: ubuntu-22.04  # seperate job on Ubuntu for easy string manipulations (compared to Windows) | ||||||
|     outputs: |     outputs: | ||||||
|       version: ${{ steps.export_version.outputs.version }} |       version: ${{ steps.export_version.outputs.version }} | ||||||
|       notes: ${{ steps.export_version.outputs.notes }} |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
| @ -34,6 +33,52 @@ jobs: | |||||||
|           node-version-file: '.nvmrc' |           node-version-file: '.nvmrc' | ||||||
|           cache: 'yarn' |           cache: 'yarn' | ||||||
|  |  | ||||||
|  |       - name: Set nightly version | ||||||
|  |         if: github.event_name == 'schedule' | ||||||
|  |         run: | | ||||||
|  |           VERSION=$(date +'%-y.%-m.%-d') yarn bump-jsons | ||||||
|  |  | ||||||
|  |       # TODO: see if we need to inject updater nightly URL here https://dl.zoo.dev/releases/modeling-app/nightly/last_update.json | ||||||
|  |       # TODO: see if we ned to add updater test URL here https://dl.zoo.dev/releases/modeling-app/updater-test/last_update.json | ||||||
|  |  | ||||||
|  |       - uses: actions/upload-artifact@v3 | ||||||
|  |         if: ${{ github.event_name == 'schedule' || env.CUT_RELEASE_PR == 'true' }} | ||||||
|  |         with: | ||||||
|  |           path: | | ||||||
|  |             package.json | ||||||
|  |  | ||||||
|  |       - id: export_version | ||||||
|  |         run: echo "version=`cat package.json | jq -r '.version'`" >> "$GITHUB_OUTPUT" | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   build-test-app-macos: | ||||||
|  |     needs: [prepare-json-files] | ||||||
|  |     runs-on: macos-14 | ||||||
|  |     env: | ||||||
|  |       APPLE_ID: ${{ secrets.APPLE_ID }} | ||||||
|  |       APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||||
|  |       APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }} | ||||||
|  |       APPLE_CERTIFICATE: ${{ secrets.APPLE_CERTIFICATE }} | ||||||
|  |       APPLE_CERTIFICATE_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||||
|  |       APPLE_SIGNING_IDENTITY: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v3 | ||||||
|  |         if: github.event_name == 'schedule' | ||||||
|  |  | ||||||
|  |       - name: Copy updated .json files | ||||||
|  |         if: github.event_name == 'schedule' | ||||||
|  |         run: | | ||||||
|  |           ls -l artifact | ||||||
|  |           cp artifact/package.json package.json | ||||||
|  |  | ||||||
|  |       - name: Sync node version and setup cache | ||||||
|  |         uses: actions/setup-node@v4 | ||||||
|  |         with: | ||||||
|  |           node-version-file: '.nvmrc' | ||||||
|  |           cache: 'yarn' # Set this to npm, yarn or pnpm. | ||||||
|  |  | ||||||
|       - run: yarn install |       - run: yarn install | ||||||
|  |  | ||||||
|       - name: Setup Rust |       - name: Setup Rust | ||||||
| @ -43,83 +88,43 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           workspaces: './src/wasm-lib' |           workspaces: './src/wasm-lib' | ||||||
|  |  | ||||||
|       # TODO: see if we can fetch from main instead if no diff at src/wasm-lib |  | ||||||
|       - name: Run build:wasm |       - name: Run build:wasm | ||||||
|         run: "yarn build:wasm" |         run: "yarn build:wasm${{ env.BUILD_RELEASE == 'true' && '-dev' || ''}}" | ||||||
|  |  | ||||||
|       - name: Set nightly version |       # TODO: sign the app (and updater bundle potentially) | ||||||
|         if: github.event_name == 'schedule' |       - name: Add signing certificate | ||||||
|         run: | |         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||||
|           VERSION=$(date +'%-y.%-m.%-d') yarn bump-jsons |         run: chmod +x add-osx-cert.sh && ./add-osx-cert.sh | ||||||
|  |  | ||||||
|       # TODO: see if we need to inject updater nightly URL here https://dl.zoo.dev/releases/modeling-app/nightly/last_update.json |       - name: Build the app for arm64 | ||||||
|  |         run: "yarn electron-forge make" | ||||||
|  |  | ||||||
|       - name: Generate release notes |       - name: Build the app for x64 | ||||||
|         env: |         run: "yarn electron-forge make --arch x64" | ||||||
|           NOTES: ${{ github.event_name == 'release' && github.event.release.body || format('Non-release build, commit {0}', github.sha) }} |  | ||||||
|         run: | |       - name: List artifacts | ||||||
|           echo "$NOTES" > release-notes.md |         run: "ls -R out/make" | ||||||
|           cat release-notes.md |  | ||||||
|  |       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: prepared-files |           path: "out/make/*/*/*/*" | ||||||
|           path: | |  | ||||||
|             package.json |  | ||||||
|             src/wasm-lib/pkg/wasm_lib* |  | ||||||
|             release-notes.md |  | ||||||
|  |  | ||||||
|       - id: export_version |  | ||||||
|         run: echo "version=`cat package.json | jq -r '.version'`" >> "$GITHUB_OUTPUT" |  | ||||||
|  |  | ||||||
|       - id: export_notes |  | ||||||
|         run: echo "notes=`cat release-notes.md'`" >> "$GITHUB_OUTPUT" |  | ||||||
|  |  | ||||||
|       - name: Prepare electron-builder.yml file for updater test |  | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |  | ||||||
|         run: | |  | ||||||
|           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/updater-test-release-notes"' electron-builder.yml |  | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v3 |  | ||||||
|         with: |  | ||||||
|           name: prepared-files-updater-test |  | ||||||
|           path: | |  | ||||||
|             electron-builder.yml |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   build-apps: |   build-test-app-windows: | ||||||
|     needs: [prepare-files] |     needs: [prepare-json-files] | ||||||
|     strategy: |     runs-on: windows-2022 | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         os: [macos-14, windows-2022, ubuntu-22.04] |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     env: |  | ||||||
|       APPLE_ID: ${{ secrets.APPLE_ID }} |  | ||||||
|       APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} |  | ||||||
|       APPLE_APP_SPECIFIC_PASSWORD: ${{ secrets.APPLE_PASSWORD }} |  | ||||||
|       APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }} |  | ||||||
|       CSC_LINK: ${{ secrets.APPLE_CERTIFICATE }} |  | ||||||
|       CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} |  | ||||||
|       CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} |  | ||||||
|       CSC_FOR_PULL_REQUEST: true |  | ||||||
|       VERSION: ${{ github.event_name == 'schedule' && needs.prepare-files.outputs.version || format('v{0}', needs.prepare-files.outputs.version) }} |  | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |  | ||||||
|       WINDOWS_CERTIFICATE_THUMBPRINT: F4C9A52FF7BC26EE5E054946F6B11DEEA94C748D |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v3 | ||||||
|         name: prepared-files |  | ||||||
|  |  | ||||||
|       - name: Copy prepared files |       - name: Copy updated .json files | ||||||
|  |         if: github.event_name == 'schedule' | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-files |           ls -l artifact | ||||||
|           cp prepared-files/package.json package.json |           cp artifact/package.json package.json | ||||||
|           cp prepared-files/src/wasm-lib/pkg/wasm_lib_bg.wasm public |  | ||||||
|           mkdir src/wasm-lib/pkg |  | ||||||
|           cp prepared-files/src/wasm-lib/pkg/wasm_lib* src/wasm-lib/pkg |  | ||||||
|           cp prepared-files/release-notes.md release-notes.md |  | ||||||
|  |  | ||||||
|       - name: Sync node version and setup cache |       - name: Sync node version and setup cache | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
| @ -129,10 +134,26 @@ jobs: | |||||||
|  |  | ||||||
|       - run: yarn install |       - run: yarn install | ||||||
|  |  | ||||||
|       - run: yarn tronb:vite |       - name: Setup Rust | ||||||
|  |         uses: dtolnay/rust-toolchain@stable | ||||||
|  |  | ||||||
|  |       - uses: Swatinem/rust-cache@v2 | ||||||
|  |         with: | ||||||
|  |           workspaces: './src/wasm-lib' | ||||||
|  |  | ||||||
|  |       - name: Run build:wasm manually | ||||||
|  |         shell: bash | ||||||
|  |         env: | ||||||
|  |           MODE: ${{ env.BUILD_RELEASE == 'true' && '--release' || '--debug' }} | ||||||
|  |         run: | | ||||||
|  |           mkdir src/wasm-lib/pkg; cd src/wasm-lib | ||||||
|  |           echo "building with ${{ env.MODE }}" | ||||||
|  |           npx wasm-pack build --target web --out-dir pkg ${{ env.MODE }} | ||||||
|  |           cd ../../ | ||||||
|  |           cp src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||||
|  |  | ||||||
|       - name: Prepare certificate and variables (Windows only) |       - name: Prepare certificate and variables (Windows only) | ||||||
|         if: ${{ env.BUILD_RELEASE == 'true' && matrix.os == 'windows-2022' }} |         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /d/Certificate_pkcs12.p12 |           echo "${{secrets.SM_CLIENT_CERT_FILE_B64 }}" | base64 --decode > /d/Certificate_pkcs12.p12 | ||||||
|           cat /d/Certificate_pkcs12.p12 |           cat /d/Certificate_pkcs12.p12 | ||||||
| @ -147,7 +168,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
|  |  | ||||||
|       - name: Setup certicate with SSM KSP (Windows only) |       - name: Setup certicate with SSM KSP (Windows only) | ||||||
|         if: ${{ env.BUILD_RELEASE == 'true' && matrix.os == 'windows-2022' }} |         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           curl -X GET  https://one.digicert.com/signingmanager/api-ui/v1/releases/smtools-windows-x64.msi/download -H "x-api-key:%SM_API_KEY%" -o smtools-windows-x64.msi |           curl -X GET  https://one.digicert.com/signingmanager/api-ui/v1/releases/smtools-windows-x64.msi/download -H "x-api-key:%SM_API_KEY%" -o smtools-windows-x64.msi | ||||||
|           msiexec /i smtools-windows-x64.msi /quiet /qn |           msiexec /i smtools-windows-x64.msi /quiet /qn | ||||||
| @ -157,42 +178,83 @@ jobs: | |||||||
|           smksp_cert_sync.exe |           smksp_cert_sync.exe | ||||||
|         shell: cmd |         shell: cmd | ||||||
|  |  | ||||||
|       - name: Build the app |       - name: Build the app for x64 | ||||||
|         run: yarn electron-builder --config ${{ env.BUILD_RELEASE && '--publish always' || '' }} |         run: "yarn electron-forge make --arch x64" | ||||||
|  |  | ||||||
|       - name: List artifacts in out/ |       - name: Build the app for arm64 | ||||||
|         run: ls -R out |         run: "yarn electron-forge make --arch arm64" | ||||||
|  |  | ||||||
|  |       - name: List artifacts | ||||||
|  |         run: "ls -R out/make" | ||||||
|  |  | ||||||
|  |       - name: Sign using Signtool | ||||||
|  |         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||||
|  |         env: | ||||||
|  |           THUMBPRINT: "F4C9A52FF7BC26EE5E054946F6B11DEEA94C748D" | ||||||
|  |           X64_FILE: "D:\\a\\modeling-app\\modeling-app\\out\\make\\squirrel.windows\\x64\\Zoo Modeling App-*Setup.exe" | ||||||
|  |           ARM64_FILE: "D:\\a\\modeling-app\\modeling-app\\out\\make\\squirrel.windows\\arm64\\Zoo Modeling App-*Setup.exe" | ||||||
|  |         run: | | ||||||
|  |           signtool.exe sign /sha1 ${{ env.THUMBPRINT }} /tr http://timestamp.digicert.com /td SHA256 /fd SHA256 "${{ env.X64_FILE }}" | ||||||
|  |           signtool.exe verify /v /pa "${{ env.X64_FILE }}" | ||||||
|  |           signtool.exe sign /sha1 ${{ env.THUMBPRINT }} /tr http://timestamp.digicert.com /td SHA256 /fd SHA256 "${{ env.ARM64_FILE }}" | ||||||
|  |           signtool.exe verify /v /pa "${{ env.ARM64_FILE }}" | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-${{ matrix.os }} |           path: "out/make/*/*/*" | ||||||
|           path: | |  | ||||||
|             out/Zoo*.* |       # TODO: Run e2e tests | ||||||
|             out/latest*.yml |  | ||||||
|  |  | ||||||
|  |   build-test-app-ubuntu: | ||||||
|  |     needs: [prepare-json-files] | ||||||
|  |     runs-on: ubuntu-22.04 | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - uses: actions/download-artifact@v3 | ||||||
|  |         if: github.event_name == 'schedule' | ||||||
|  |  | ||||||
|  |       - name: Copy updated .json files | ||||||
|  |         if: github.event_name == 'schedule' | ||||||
|  |         run: | | ||||||
|  |           ls -l artifact | ||||||
|  |           cp artifact/package.json package.json | ||||||
|  |  | ||||||
|  |       - name: Sync node version and setup cache | ||||||
|  |         uses: actions/setup-node@v4 | ||||||
|  |         with: | ||||||
|  |           node-version-file: '.nvmrc' | ||||||
|  |           cache: 'yarn' # Set this to npm, yarn or pnpm. | ||||||
|  |  | ||||||
|  |       - run: yarn install | ||||||
|  |  | ||||||
|  |       - name: Setup Rust | ||||||
|  |         uses: dtolnay/rust-toolchain@stable | ||||||
|  |  | ||||||
|  |       - uses: Swatinem/rust-cache@v2 | ||||||
|  |         with: | ||||||
|  |           workspaces: './src/wasm-lib' | ||||||
|  |  | ||||||
|  |       - name: Run build:wasm | ||||||
|  |         run: "yarn build:wasm${{ env.BUILD_RELEASE == 'true' && '-dev' || ''}}" | ||||||
|  |  | ||||||
|  |       - name: Build the app for arm64 | ||||||
|  |         run: "yarn electron-forge make --arch arm64" | ||||||
|  |  | ||||||
|  |       - name: Build the app for x64 | ||||||
|  |         run: "yarn electron-forge make --arch x64" | ||||||
|  |  | ||||||
|  |       - name: List artifacts | ||||||
|  |         run: "ls -R out/make" | ||||||
|  |  | ||||||
|       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back |       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v3 |       # TODO: sign the app (and updater bundle potentially) | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |  | ||||||
|         name: prepared-files-updater-test |  | ||||||
|  |  | ||||||
|       - name: Copy updated electron-builder.yml file for updater test |  | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |  | ||||||
|         run: | |  | ||||||
|           ls -R prepared-files-updater-test |  | ||||||
|           cp prepared-files-updater-test/electron-builder.yml electron-builder.yml |  | ||||||
|  |  | ||||||
|       - name: Build the app (updater-test) |  | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |  | ||||||
|         run: yarn electron-builder --config ${{ env.BUILD_RELEASE && '--publish always' || '' }} |  | ||||||
|  |  | ||||||
|       - uses: actions/upload-artifact@v3 |       - uses: actions/upload-artifact@v3 | ||||||
|         if: ${{ env.CUT_RELEASE_PR == 'true' }} |  | ||||||
|         with: |         with: | ||||||
|           name: updater-test-${{ matrix.os }} |           path: "out/make/*/*/*" | ||||||
|           path: | |  | ||||||
|             out/Zoo*.* |  | ||||||
|             out/latest*.yml |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   publish-apps-release: |   publish-apps-release: | ||||||
| @ -200,104 +262,114 @@ jobs: | |||||||
|     permissions: |     permissions: | ||||||
|       contents: write |       contents: write | ||||||
|     if: ${{ github.event_name == 'release' || github.event_name == 'schedule' }} |     if: ${{ github.event_name == 'release' || github.event_name == 'schedule' }} | ||||||
|     needs: [prepare-files, build-apps] |     needs: [prepare-json-files, build-test-app-macos, build-test-app-windows, build-test-app-ubuntu] | ||||||
|     env: |     env: | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |       VERSION_NO_V: ${{ needs.prepare-json-files.outputs.version }} | ||||||
|       VERSION: ${{ github.event_name == 'schedule' && needs.prepare-files.outputs.version || format('v{0}', needs.prepare-files.outputs.version) }} |       VERSION: ${{ github.event_name == 'release' && format('v{0}', needs.prepare-json-files.outputs.version) || needs.prepare-json-files.outputs.version }} | ||||||
|       PUB_DATE: ${{ github.event_name == 'release' && github.event.release.created_at || github.event.repository.updated_at }} |       PUB_DATE: ${{ github.event_name == 'release' && github.event.release.created_at || github.event.repository.updated_at }} | ||||||
|       NOTES: ${{ needs.prepare-files.outputs.notes }} |       NOTES: ${{ github.event_name == 'release' && github.event.release.body || format('Nightly build, commit {0}', github.sha) }} | ||||||
|       BUCKET_DIR: ${{ github.event_name == 'schedule' && 'dl.kittycad.io/releases/modeling-app/nightly' || 'dl.kittycad.io/releases/modeling-app' }} |       BUCKET_DIR: ${{ github.event_name == 'release' && 'dl.kittycad.io/releases/modeling-app' || 'dl.kittycad.io/releases/modeling-app/nightly' }} | ||||||
|       WEBSITE_DIR: ${{ github.event_name == 'schedule' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} |       WEBSITE_DIR: ${{ github.event_name == 'release' && 'dl.zoo.dev/releases/modeling-app' || 'dl.zoo.dev/releases/modeling-app/nightly' }} | ||||||
|       URL_CODED_NAME: ${{ github.event_name == 'schedule' && 'Zoo%20Modeling%20App%20%28Nightly%29' || 'Zoo%20Modeling%20App' }} |       URL_CODED_NAME: ${{ github.event_name == 'schedule' && 'Zoo%20Modeling%20App%20%28Nightly%29' || 'Zoo%20Modeling%20App' }} | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v3 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |  | ||||||
|           name: out-windows-2022 |  | ||||||
|           path: out |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v3 |       - name: Generate the update static endpoint | ||||||
|         with: |  | ||||||
|           name: out-macos-14 |  | ||||||
|           path: out |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v3 |  | ||||||
|         with: |  | ||||||
|           name: out-ubuntu-22.04 |  | ||||||
|           path: out |  | ||||||
|  |  | ||||||
|       - name: Generate the download static endpoint |  | ||||||
|         run: | |         run: | | ||||||
|           RELEASE_DIR=https://${WEBSITE_DIR} |           ls -l artifact/*/*oo* | ||||||
|  |           DARWIN_SIG=`cat artifact/macos/*.app.tar.gz.sig` | ||||||
|  |           WINDOWS_X86_64_SIG=`cat artifact/msi/*x64*.msi.zip.sig` | ||||||
|  |           WINDOWS_AARCH64_SIG=`cat artifact/msi/*arm64*.msi.zip.sig` | ||||||
|  |           RELEASE_DIR=https://${WEBSITE_DIR}/${VERSION} | ||||||
|           jq --null-input \ |           jq --null-input \ | ||||||
|             --arg version "${VERSION}" \ |             --arg version "${VERSION}" \ | ||||||
|             --arg pub_date "${PUB_DATE}" \ |             --arg pub_date "${PUB_DATE}" \ | ||||||
|             --arg notes "${NOTES}" \ |             --arg notes "${NOTES}" \ | ||||||
|             --arg mac_arm64_url "$RELEASE_DIR/${{ env.URL_CODED_NAME }}-${VERSION_NO_V}-arm64-mac.dmg" \ |             --arg darwin_sig "$DARWIN_SIG" \ | ||||||
|             --arg mac_x64_url "$RELEASE_DIR/${{ env.URL_CODED_NAME }}-${VERSION_NO_V}-x64-mac.dmg" \ |             --arg darwin_url "$RELEASE_DIR/macos/${{ env.URL_CODED_NAME }}.app.tar.gz" \ | ||||||
|             --arg windows_arm64_url "$RELEASE_DIR/${{ env.URL_CODED_NAME }}-${VERSION_NO_V}-arm64-win.exe" \ |             --arg windows_x86_64_sig "$WINDOWS_X86_64_SIG" \ | ||||||
|             --arg windows_x64_url "$RELEASE_DIR/${{ env.URL_CODED_NAME }}-${VERSION_NO_V}-x64-win.exe" \ |             --arg windows_x86_64_url "$RELEASE_DIR/msi/${{ env.URL_CODED_NAME }}_${VERSION_NO_V}_x64_en-US.msi.zip" \ | ||||||
|             --arg linux_arm64_url "$RELEASE_DIR/${{ env.URL_CODED_NAME }}-${VERSION_NO_V}-arm64-linux.AppImage" \ |             --arg windows_aarch64_sig "$WINDOWS_AARCH64_SIG" \ | ||||||
|             --arg linux_x64_url "$RELEASE_DIR/${{ env.URL_CODED_NAME }}-${VERSION_NO_V}-x86_64-linux.AppImage" \ |             --arg windows_aarch64_url "$RELEASE_DIR/msi/${{ env.URL_CODED_NAME }}_${VERSION_NO_V}_arm64_en-US.msi.zip" \ | ||||||
|             '{ |             '{ | ||||||
|               "version": $version, |               "version": $version, | ||||||
|               "pub_date": $pub_date, |               "pub_date": $pub_date, | ||||||
|               "notes": $notes, |               "notes": $notes, | ||||||
|               "platforms": { |               "platforms": { | ||||||
|                 "dmg-arm64": { |                 "darwin-x86_64": { | ||||||
|                   "url": $mac_arm64_url |                   "signature": $darwin_sig, | ||||||
|  |                   "url": $darwin_url | ||||||
|                 }, |                 }, | ||||||
|                 "dmg-x64": { |                 "darwin-aarch64": { | ||||||
|                   "url": $mac_x64_url |                   "signature": $darwin_sig, | ||||||
|  |                   "url": $darwin_url | ||||||
|                 }, |                 }, | ||||||
|                 "exe-arm64": { |                 "windows-x86_64": { | ||||||
|                   "url": $windows_arm64_url |                   "signature": $windows_x86_64_sig, | ||||||
|  |                   "url": $windows_x86_64_url | ||||||
|                 }, |                 }, | ||||||
|                 "exe-x64": { |                 "windows-aarch64": { | ||||||
|                   "url": $windows_x64_url |                   "signature": $windows_aarch64_sig, | ||||||
|  |                   "url": $windows_aarch64_url | ||||||
|  |                 } | ||||||
|  |               } | ||||||
|  |             }' > last_update.json | ||||||
|  |             cat last_update.json | ||||||
|  |  | ||||||
|  |       - name: Generate the download static endpoint | ||||||
|  |         run: | | ||||||
|  |           RELEASE_DIR=https://${WEBSITE_DIR}/${VERSION} | ||||||
|  |           jq --null-input \ | ||||||
|  |             --arg version "${VERSION}" \ | ||||||
|  |             --arg pub_date "${PUB_DATE}" \ | ||||||
|  |             --arg notes "${NOTES}" \ | ||||||
|  |             --arg darwin_url "$RELEASE_DIR/dmg/${{ env.URL_CODED_NAME }}_${VERSION_NO_V}_universal.dmg" \ | ||||||
|  |             --arg windows_x86_64_url "$RELEASE_DIR/msi/${{ env.URL_CODED_NAME }}_${VERSION_NO_V}_x64_en-US.msi" \ | ||||||
|  |             --arg windows_aarch64_url "$RELEASE_DIR/msi/${{ env.URL_CODED_NAME }}_${VERSION_NO_V}_arm64_en-US.msi" \ | ||||||
|  |             '{ | ||||||
|  |               "version": $version, | ||||||
|  |               "pub_date": $pub_date, | ||||||
|  |               "notes": $notes, | ||||||
|  |               "platforms": { | ||||||
|  |                 "dmg-universal": { | ||||||
|  |                   "url": $darwin_url | ||||||
|                 }, |                 }, | ||||||
|                 "appimage-arm64": { |                 "msi-x86_64": { | ||||||
|                   "url": $linux_arm64_url |                   "url": $windows_x86_64_url | ||||||
|                 }, |                 }, | ||||||
|                 "appimage-x64": { |                 "msi-aarch64": { | ||||||
|                   "url": $linux_x64_url |                   "url": $windows_aarch64_url | ||||||
|                 } |                 } | ||||||
|               } |               } | ||||||
|             }' > last_download.json |             }' > last_download.json | ||||||
|             cat last_download.json |             cat last_download.json | ||||||
|  |  | ||||||
|       - name: List artifacts |  | ||||||
|         run: "ls -R out" |  | ||||||
|  |  | ||||||
|       - name: Authenticate to Google Cloud |       - name: Authenticate to Google Cloud | ||||||
|         uses: 'google-github-actions/auth@v2.1.6' |         uses: 'google-github-actions/auth@v2.1.5' | ||||||
|         with: |         with: | ||||||
|           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' |           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' | ||||||
|  |  | ||||||
|       - name: Set up Google Cloud SDK |       - name: Set up Google Cloud SDK | ||||||
|         uses: google-github-actions/setup-gcloud@v2.1.0 |         uses: google-github-actions/setup-gcloud@v2.1.0 | ||||||
|         with: |         with: | ||||||
|           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} |           project_id: kittycadapi | ||||||
|  |  | ||||||
|       - name: Upload release files to public bucket |       - name: Upload release files to public bucket | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.0 |         uses: google-github-actions/upload-cloud-storage@v2.1.3 | ||||||
|         with: |         with: | ||||||
|           path: out |           path: artifact | ||||||
|           glob: 'Zoo*' |           glob: '*/Zoo*' | ||||||
|           parent: false |           parent: false | ||||||
|           destination: ${{ env.BUCKET_DIR }} |           destination: ${{ env.BUCKET_DIR }}/${{ env.VERSION }} | ||||||
|  |  | ||||||
|       - name: Upload update endpoint to public bucket |       - name: Upload update endpoint to public bucket | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.0 |         uses: google-github-actions/upload-cloud-storage@v2.1.3 | ||||||
|         with: |         with: | ||||||
|           path: out |           path: last_update.json | ||||||
|           glob: 'latest*' |  | ||||||
|           parent: false |  | ||||||
|           destination: ${{ env.BUCKET_DIR }} |           destination: ${{ env.BUCKET_DIR }} | ||||||
|  |  | ||||||
|       - name: Upload download endpoint to public bucket |       - name: Upload download endpoint to public bucket | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.0 |         uses: google-github-actions/upload-cloud-storage@v2.1.3 | ||||||
|         with: |         with: | ||||||
|           path: last_download.json |           path: last_download.json | ||||||
|           destination: ${{ env.BUCKET_DIR }} |           destination: ${{ env.BUCKET_DIR }} | ||||||
| @ -306,14 +378,7 @@ jobs: | |||||||
|         if: ${{ github.event_name == 'release' }} |         if: ${{ github.event_name == 'release' }} | ||||||
|         uses: softprops/action-gh-release@v2 |         uses: softprops/action-gh-release@v2 | ||||||
|         with: |         with: | ||||||
|           files: 'out/Zoo*' |           files: 'artifact/*/Zoo*' | ||||||
|  |  | ||||||
|       - name: Invalidate bucket cache on latest*.yml and last_download.json files |  | ||||||
|         run: | |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/last_download.json" --async |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest-linux-arm64.yml" --async |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest-mac.yml" --async |  | ||||||
|           gcloud compute url-maps invalidate-cdn-cache dl-url-map --path="/releases/modeling-app/latest.yml" --async |  | ||||||
|  |  | ||||||
|   announce_release: |   announce_release: | ||||||
|     needs: [publish-apps-release] |     needs: [publish-apps-release] | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| name: Static Analysis | name: build-test-web | ||||||
| 
 | 
 | ||||||
| on: | on: | ||||||
|   pull_request: |   pull_request: | ||||||
| @ -16,7 +16,7 @@ permissions: | |||||||
|   actions: read |   actions: read | ||||||
| 
 | 
 | ||||||
| jobs: | jobs: | ||||||
|   yarn-fmt-check: |   check-format: | ||||||
|     runs-on: 'ubuntu-22.04' |     runs-on: 'ubuntu-22.04' | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @ -27,23 +27,7 @@ jobs: | |||||||
|       - run: yarn install |       - run: yarn install | ||||||
|       - run: yarn fmt-check |       - run: yarn fmt-check | ||||||
| 
 | 
 | ||||||
|   yarn-build-wasm: |   check-types: | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
| 
 |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|       - uses: actions/setup-node@v4 |  | ||||||
|         with: |  | ||||||
|           node-version-file: '.nvmrc' |  | ||||||
|           cache: 'yarn' |  | ||||||
|       - run: yarn install |  | ||||||
|       - uses: Swatinem/rust-cache@v2 |  | ||||||
|         with: |  | ||||||
|           workspaces: './src/wasm-lib' |  | ||||||
| 
 |  | ||||||
|       - run: yarn build:wasm |  | ||||||
| 
 |  | ||||||
|   yarn-tsc: |  | ||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
| 
 | 
 | ||||||
|     steps: |     steps: | ||||||
| @ -58,25 +42,13 @@ jobs: | |||||||
|           workspaces: './src/wasm-lib' |           workspaces: './src/wasm-lib' | ||||||
| 
 | 
 | ||||||
|       - run: yarn build:wasm |       - run: yarn build:wasm | ||||||
|  |       - run: yarn xstate:typegen | ||||||
|       - run: yarn tsc |       - run: yarn tsc | ||||||
|  |       - name: Lint | ||||||
|  |         run: yarn eslint --max-warnings 0 src e2e | ||||||
| 
 | 
 | ||||||
|   yarn-lint: |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
| 
 | 
 | ||||||
|     steps: |   check-typos: | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|       - uses: actions/setup-node@v4 |  | ||||||
|         with: |  | ||||||
|           node-version-file: '.nvmrc' |  | ||||||
|           cache: 'yarn' |  | ||||||
|       - run: yarn install |  | ||||||
|       - uses: Swatinem/rust-cache@v2 |  | ||||||
|         with: |  | ||||||
|           workspaces: './src/wasm-lib' |  | ||||||
| 
 |  | ||||||
|       - run: yarn lint |  | ||||||
| 
 |  | ||||||
|   python-codespell: |  | ||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout |       - name: Checkout | ||||||
| @ -90,7 +62,7 @@ jobs: | |||||||
|         run: codespell --config .codespellrc # Edit this file to tweak the typo list and other configuration. |         run: codespell --config .codespellrc # Edit this file to tweak the typo list and other configuration. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   yarn-unit-test: |   build-test-web: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| @ -108,7 +80,7 @@ jobs: | |||||||
| 
 | 
 | ||||||
|       - run: yarn build:wasm |       - run: yarn build:wasm | ||||||
| 
 | 
 | ||||||
|       - run: yarn simpleserver:bg |       - run: yarn simpleserver:ci | ||||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} |         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||||
| 
 | 
 | ||||||
|       - name: Install Chromium Browser |       - name: Install Chromium Browser | ||||||
| @ -117,7 +89,7 @@ jobs: | |||||||
| 
 | 
 | ||||||
|       - name: run unit tests |       - name: run unit tests | ||||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} |         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} | ||||||
|         run: yarn test:unit |         run: yarn test:nowatch | ||||||
|         env: |         env: | ||||||
|           VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |           VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
| 
 | 
 | ||||||
							
								
								
									
										3
									
								
								.github/workflows/cargo-clippy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/cargo-clippy.yml
									
									
									
									
										vendored
									
									
								
							| @ -28,7 +28,6 @@ jobs: | |||||||
|         dir: ['src/wasm-lib'] |         dir: ['src/wasm-lib'] | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
|       - uses: taiki-e/install-action@just |  | ||||||
|       - name: Install latest rust |       - name: Install latest rust | ||||||
|         uses: actions-rs/toolchain@v1 |         uses: actions-rs/toolchain@v1 | ||||||
|         with: |         with: | ||||||
| @ -42,7 +41,7 @@ jobs: | |||||||
|       - name: Run clippy |       - name: Run clippy | ||||||
|         run: | |         run: | | ||||||
|           cd "${{ matrix.dir }}" |           cd "${{ matrix.dir }}" | ||||||
|           just lint |           cargo clippy --all --tests --benches -- -D warnings | ||||||
|       # If this fails, run "cargo check" to update Cargo.lock, |       # If this fails, run "cargo check" to update Cargo.lock, | ||||||
|       # then add Cargo.lock to the PR. |       # then add Cargo.lock to the PR. | ||||||
|       - name: Check Cargo.lock doesn't need updating |       - name: Check Cargo.lock doesn't need updating | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -4,7 +4,6 @@ on: | |||||||
|       - main |       - main | ||||||
|     paths: |     paths: | ||||||
|       - 'src/wasm-lib/**.rs' |       - 'src/wasm-lib/**.rs' | ||||||
|       - 'src/wasm-lib/**.hbs' |  | ||||||
|       - '**/Cargo.toml' |       - '**/Cargo.toml' | ||||||
|       - '**/Cargo.lock' |       - '**/Cargo.lock' | ||||||
|       - '**/rust-toolchain.toml' |       - '**/rust-toolchain.toml' | ||||||
| @ -14,7 +13,6 @@ on: | |||||||
|   pull_request: |   pull_request: | ||||||
|     paths: |     paths: | ||||||
|       - 'src/wasm-lib/**.rs' |       - 'src/wasm-lib/**.rs' | ||||||
|       - 'src/wasm-lib/**.hbs' |  | ||||||
|       - '**/Cargo.toml' |       - '**/Cargo.toml' | ||||||
|       - '**/Cargo.lock' |       - '**/Cargo.lock' | ||||||
|       - '**/rust-toolchain.toml' |       - '**/rust-toolchain.toml' | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/generate-website-docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/generate-website-docs.yml
									
									
									
									
										vendored
									
									
								
							| @ -38,10 +38,8 @@ jobs: | |||||||
|           mkdir -p documentation/content/pages/docs/kcl/ |           mkdir -p documentation/content/pages/docs/kcl/ | ||||||
|           # cleanup old |           # cleanup old | ||||||
|           rm -rf documentation/content/pages/docs/kcl/*.md |           rm -rf documentation/content/pages/docs/kcl/*.md | ||||||
|           rm -rf documentation/content/pages/docs/kcl/types |  | ||||||
|           # move new |           # move new | ||||||
|           mv -f docs/kcl/*.md documentation/content/pages/docs/kcl/ |           mv -f docs/kcl/*.md documentation/content/pages/docs/kcl/ | ||||||
|           mv -f docs/kcl/types documentation/content/pages/docs/kcl/ |  | ||||||
|       - name: commit the changes in the docs repo |       - name: commit the changes in the docs repo | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: | |         run: | | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| name: E2E Tests | name: Playwright Tests | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ main ] |     branches: [ main ] | ||||||
| @ -33,9 +33,8 @@ jobs: | |||||||
|             rust: |             rust: | ||||||
|               - 'src/wasm-lib/**' |               - 'src/wasm-lib/**' | ||||||
| 
 | 
 | ||||||
|   browser: |   playwright-chrome: | ||||||
|     timeout-minutes: ${{ matrix.os == 'macos-14' && 60 || 50 }} |     timeout-minutes: ${{ matrix.os == 'macos-14' && 60 || 40 }} | ||||||
|     name: playwright:browser:${{ matrix.os }} ${{ matrix.shardIndex }} ${{ matrix.shardTotal }} |  | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
| @ -140,9 +139,8 @@ jobs: | |||||||
|     - uses: actions/upload-artifact@v4 |     - uses: actions/upload-artifact@v4 | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|       with: |       with: | ||||||
|         name: playwright-report-${{ matrix.os }}-snapshot-${{ matrix.shardIndex }}-${{ github.sha }} |         name: playwright-report-ubuntu-snapshot-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|         path: playwright-report/ |         path: playwright-report/ | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |         retention-days: 30 | ||||||
|         overwrite: true |         overwrite: true | ||||||
|     - name: Clean up test-results |     - name: Clean up test-results | ||||||
| @ -176,25 +174,64 @@ jobs: | |||||||
|     - uses: actions/upload-artifact@v4 |     - uses: actions/upload-artifact@v4 | ||||||
|       if: steps.git-check.outputs.modified == 'true' |       if: steps.git-check.outputs.modified == 'true' | ||||||
|       with: |       with: | ||||||
|         name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |         name: playwright-report-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|         path: playwright-report/ |         path: playwright-report/ | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |         retention-days: 30 | ||||||
|     - uses: actions/download-artifact@v4 |     - uses: actions/download-artifact@v4 | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|       continue-on-error: true |       continue-on-error: true | ||||||
|       with: |       with: | ||||||
|         name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |         name: test-results-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|         path: test-results/ |         path: test-results/ | ||||||
|     - name: Run playwright/chrome flow (with retries) |     - name: Run playwright/chrome flow (with retries) | ||||||
|       id: retry |       id: retry | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|       shell: bash |       shell: bash | ||||||
|       run: | |       run: | | ||||||
|         .github/ci-cd-scripts/playwright-browser-chrome.sh ${{matrix.shardIndex}} ${{matrix.shardTotal}} ${{matrix.os}} |         if [[ ! -f "test-results/.last-run.json" ]]; then | ||||||
|  |             # if no last run artifact, than run plawright normally | ||||||
|  |             echo "run playwright normally" | ||||||
|  |             yarn playwright test --project="Google Chrome" --config=playwright.ci.config.ts --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} --grep-invert="@snapshot|@electron" || true | ||||||
|  |             # # send to axiom | ||||||
|  |             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||||
|  |         fi | ||||||
|  | 
 | ||||||
|  |         retry=1 | ||||||
|  |         max_retrys=4 | ||||||
|  | 
 | ||||||
|  |         # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||||
|  |         while [[ $retry -le $max_retrys ]]; do | ||||||
|  |             if [[ -f "test-results/.last-run.json" ]]; then | ||||||
|  |                 failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||||
|  |                 if [[ $failed_tests -gt 0 ]]; then | ||||||
|  |                     echo "retried=true" >>$GITHUB_OUTPUT | ||||||
|  |                     echo "run playwright with last failed tests and retry $retry" | ||||||
|  |                     yarn playwright test --project="Google Chrome" --config=playwright.ci.config.ts --last-failed --grep-invert="@snapshot|@electron" || true | ||||||
|  |                     # send to axiom | ||||||
|  |                     node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||||
|  |                     retry=$((retry + 1)) | ||||||
|  |                 else | ||||||
|  |                     echo "retried=false" >>$GITHUB_OUTPUT | ||||||
|  |                     exit 0 | ||||||
|  |                 fi | ||||||
|  |             else | ||||||
|  |                 echo "retried=false" >>$GITHUB_OUTPUT | ||||||
|  |                 exit 0 | ||||||
|  |             fi | ||||||
|  |         done | ||||||
|  | 
 | ||||||
|  |         echo "retried=false" >>$GITHUB_OUTPUT | ||||||
|  | 
 | ||||||
|  |         if [[ -f "test-results/.last-run.json" ]]; then | ||||||
|  |             failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||||
|  |             if [[ $failed_tests -gt 0 ]]; then | ||||||
|  |                 # if it still fails after 3 retrys, then fail the job | ||||||
|  |                 exit 1 | ||||||
|  |             fi | ||||||
|  |         fi | ||||||
|  |         exit 0 | ||||||
|       env: |       env: | ||||||
|         CI: true |         CI: true | ||||||
|         FAIL_ON_CONSOLE_ERRORS: true |  | ||||||
|         NODE_ENV: development |         NODE_ENV: development | ||||||
|         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|         VITE_KC_SKIP_AUTH: true |         VITE_KC_SKIP_AUTH: true | ||||||
| @ -207,28 +244,25 @@ jobs: | |||||||
|     - uses: actions/upload-artifact@v4 |     - uses: actions/upload-artifact@v4 | ||||||
|       if: always() |       if: always() | ||||||
|       with: |       with: | ||||||
|         name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |         name: test-results-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|         path: test-results/ |         path: test-results/ | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |         retention-days: 30 | ||||||
|         overwrite: true |         overwrite: true | ||||||
|     - uses: actions/upload-artifact@v4 |     - uses: actions/upload-artifact@v4 | ||||||
|       if: always() |       if: always() | ||||||
|       with: |       with: | ||||||
|         name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |         name: playwright-report-ubuntu-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|         path: playwright-report/ |         path: playwright-report/ | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |         retention-days: 30 | ||||||
|         overwrite: true |         overwrite: true | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   electron: |   playwright-electron: | ||||||
|     name: playwright:electron:${{matrix.os}} |  | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ubuntu-latest, windows-latest, macos-14] |         os: [ubuntu-latest, windows-latest, macos-14] | ||||||
|     timeout-minutes: 60 |     timeout-minutes: 30 | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     needs: check-rust-changes |     needs: check-rust-changes | ||||||
|     steps: |     steps: | ||||||
| @ -317,17 +351,65 @@ jobs: | |||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|       continue-on-error: true |       continue-on-error: true | ||||||
|       with: |       with: | ||||||
|         name: test-results-electron-${{ matrix.os }}-${{ github.sha }} |         name: test-results-ubuntu-${{ github.sha }} | ||||||
|         path: test-results/ |         path: test-results/ | ||||||
|     - name: Run electron tests (with retries) |     - name: Run electron tests (with retries) | ||||||
|       id: retry |       id: retry | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|       shell: bash |       shell: bash | ||||||
|       run: | |       run: | | ||||||
|         .github/ci-cd-scripts/playwright-electron.sh ${{ matrix.os }} |         if [[ ! -f "test-results/.last-run.json" ]]; then | ||||||
|  |             # if no last run artifact, than run plawright normally | ||||||
|  |             echo "run playwright normally" | ||||||
|  |             if [[ "$IS_UBUNTU" == "true" ]]; then | ||||||
|  |               xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn playwright test --config=playwright.electron.config.ts --grep=@electron || true | ||||||
|  |             else | ||||||
|  |               yarn playwright test --config=playwright.electron.config.ts --grep=@electron || true | ||||||
|  |             fi | ||||||
|  |             # # send to axiom | ||||||
|  |             node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||||
|  |         fi | ||||||
|  | 
 | ||||||
|  |         retry=1 | ||||||
|  |         max_retrys=2 | ||||||
|  | 
 | ||||||
|  |         # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||||
|  |         while [[ $retry -le $max_retrys ]]; do | ||||||
|  |             if [[ -f "test-results/.last-run.json" ]]; then | ||||||
|  |                 failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||||
|  |                 if [[ $failed_tests -gt 0 ]]; then | ||||||
|  |                     echo "retried=true" >>$GITHUB_OUTPUT | ||||||
|  |                     echo "run playwright with last failed tests and retry $retry" | ||||||
|  |                     if [[ "$IS_UBUNTU" == "true" ]]; then | ||||||
|  |                       xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn playwright test --config=playwright.electron.config.ts --grep=@electron || true | ||||||
|  |                     else | ||||||
|  |                       yarn playwright test --config=playwright.electron.config.ts --grep=@electron || true | ||||||
|  |                     fi | ||||||
|  |                     # send to axiom | ||||||
|  |                     node playwrightProcess.mjs | tee /tmp/github-actions.log > /dev/null 2>&1 | ||||||
|  |                     retry=$((retry + 1)) | ||||||
|  |                 else | ||||||
|  |                     echo "retried=false" >>$GITHUB_OUTPUT | ||||||
|  |                     exit 0 | ||||||
|  |                 fi | ||||||
|  |             else | ||||||
|  |                 echo "retried=false" >>$GITHUB_OUTPUT | ||||||
|  |                 exit 0 | ||||||
|  |             fi | ||||||
|  |         done | ||||||
|  | 
 | ||||||
|  |         echo "retried=false" >>$GITHUB_OUTPUT | ||||||
|  | 
 | ||||||
|  |         if [[ -f "test-results/.last-run.json" ]]; then | ||||||
|  |             failed_tests=$(jq '.failedTests | length' test-results/.last-run.json) | ||||||
|  |             if [[ $failed_tests -gt 0 ]]; then | ||||||
|  |                 # if it still fails after 3 retrys, then fail the job | ||||||
|  |                 exit 1 | ||||||
|  |             fi | ||||||
|  |         fi | ||||||
|  |         exit 0 | ||||||
|       env: |       env: | ||||||
|         CI: true |         CI: true | ||||||
|         FAIL_ON_CONSOLE_ERRORS: true |  | ||||||
|         NODE_ENV: development |         NODE_ENV: development | ||||||
|         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|         VITE_KC_SKIP_AUTH: true |         VITE_KC_SKIP_AUTH: true | ||||||
| @ -343,7 +425,6 @@ jobs: | |||||||
|       with: |       with: | ||||||
|         name: test-results-electron-${{ matrix.os }}-${{ github.sha }} |         name: test-results-electron-${{ matrix.os }}-${{ github.sha }} | ||||||
|         path: test-results/ |         path: test-results/ | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |         retention-days: 30 | ||||||
|         overwrite: true |         overwrite: true | ||||||
|     - uses: actions/upload-artifact@v4 |     - uses: actions/upload-artifact@v4 | ||||||
| @ -351,6 +432,5 @@ jobs: | |||||||
|       with: |       with: | ||||||
|         name: playwright-report-electron-${{ matrix.os }}-${{ github.sha }} |         name: playwright-report-electron-${{ matrix.os }}-${{ github.sha }} | ||||||
|         path: playwright-report/ |         path: playwright-report/ | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |         retention-days: 30 | ||||||
|         overwrite: true |         overwrite: true | ||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -59,7 +59,6 @@ src/wasm-lib/grackle/stdlib_cube_partial.json | |||||||
| Mac_App_Distribution.provisionprofile | Mac_App_Distribution.provisionprofile | ||||||
|  |  | ||||||
| *.tsbuildinfo | *.tsbuildinfo | ||||||
| src/wasm-lib/pkg |  | ||||||
|  |  | ||||||
| venv | venv | ||||||
| .vite/ | .vite/ | ||||||
|  | |||||||
| @ -5,7 +5,6 @@ coverage | |||||||
|  |  | ||||||
| # Ignore Rust projects: | # Ignore Rust projects: | ||||||
| *.rs | *.rs | ||||||
| *.hbs |  | ||||||
| target | target | ||||||
| src/wasm-lib/pkg | src/wasm-lib/pkg | ||||||
| src/wasm-lib/kcl/bindings | src/wasm-lib/kcl/bindings | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								Makefile
									
									
									
									
									
								
							| @ -7,14 +7,6 @@ XSTATE_TYPEGENS := $(wildcard src/machines/*.typegen.ts) | |||||||
| dev: node_modules public/wasm_lib_bg.wasm $(XSTATE_TYPEGENS) | dev: node_modules public/wasm_lib_bg.wasm $(XSTATE_TYPEGENS) | ||||||
| 	yarn start | 	yarn start | ||||||
|  |  | ||||||
| # I'm sorry this is so specific to my setup you may as well ignore this. |  | ||||||
| # This is so you don't have to deal with electron windows popping up constantly. |  | ||||||
| # It should work for you other Linux users. |  | ||||||
| lee-electron-test: |  | ||||||
| 	Xephyr -br -ac -noreset -screen 1200x500 :2 & |  | ||||||
| 	DISPLAY=:2 NODE_ENV=development PW_TEST_CONNECT_WS_ENDPOINT=ws://127.0.0.1:4444/ yarn tron:test -g "when using the file tree" |  | ||||||
| 	killall Xephyr |  | ||||||
|  |  | ||||||
| $(XSTATE_TYPEGENS): $(TS_SRC) | $(XSTATE_TYPEGENS): $(TS_SRC) | ||||||
| 	yarn xstate typegen 'src/**/*.ts?(x)' | 	yarn xstate typegen 'src/**/*.ts?(x)' | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										140
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										140
									
								
								README.md
									
									
									
									
									
								
							| @ -2,7 +2,7 @@ | |||||||
|  |  | ||||||
| ## Zoo Modeling App | ## Zoo Modeling App | ||||||
|  |  | ||||||
| download at [zoo.dev/modeling-app/download](https://zoo.dev/modeling-app/download) | live at [app.zoo.dev](https://app.zoo.dev/) | ||||||
|  |  | ||||||
| A CAD application from the future, brought to you by the [Zoo team](https://zoo.dev). | A CAD application from the future, brought to you by the [Zoo team](https://zoo.dev). | ||||||
|  |  | ||||||
| @ -57,7 +57,7 @@ yarn install | |||||||
| followed by: | followed by: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| yarn build:wasm | yarn build:wasm-dev | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| or if you have the gh cli installed | or if you have the gh cli installed | ||||||
| @ -66,15 +66,15 @@ or if you have the gh cli installed | |||||||
| ./get-latest-wasm-bundle.sh # this will download the latest main wasm bundle | ./get-latest-wasm-bundle.sh # this will download the latest main wasm bundle | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| That will build the WASM binary and put in the `public` dir (though gitignored). | That will build the WASM binary and put in the `public` dir (though gitignored) | ||||||
|  |  | ||||||
| Finally, to run the web app only, run: | finally, to run the web app only, run: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| yarn start | yarn start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| If you're not an KittyCAD employee you won't be able to access the dev environment, you should copy everything from `.env.production` to `.env.development` to make it point to production instead, then when you navigate to `localhost:3000` the easiest way to sign in is to paste `localStorage.setItem('TOKEN_PERSIST_KEY', "your-token-from-https://zoo.dev/account/api-tokens")` replacing the with a real token from https://zoo.dev/account/api-tokens of course, then navigate to localhost:3000 again. Note that navigating to `localhost:3000/signin` removes your token so you will need to set the token again. | If you're not an KittyCAD employee you won't be able to access the dev environment, you should copy everything from `.env.production` to `.env.development` to make it point to production instead, then when you navigate to `localhost:3000` the easiest way to sign in is to paste `localStorage.setItem('TOKEN_PERSIST_KEY', "your-token-from-https://zoo.dev/account/api-tokens")` replacing the with a real token from https://zoo.dev/account/api-tokens ofcourse, then navigate to localhost:3000 again. Note that navigating to localhost:3000/signin removes your token so you will need to set the token again. | ||||||
|  |  | ||||||
| ### Development environment variables | ### Development environment variables | ||||||
|  |  | ||||||
| @ -91,13 +91,13 @@ Third-Party Cookies". | |||||||
|  |  | ||||||
| ## Desktop | ## Desktop | ||||||
|  |  | ||||||
| To spin up the desktop app, `yarn install` and `yarn build:wasm` need to have been done before hand then | To spin up the desktop app, `yarn install` and `yarn build:wasm-dev` need to have been done before hand then | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| yarn tron:start | yarn electron:start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| This will start the application and hot-reload on changes. | This will start the application and hot-reload on changed. | ||||||
|  |  | ||||||
| Devtools can be opened with the usual Cmd/Ctrl-Shift-I. | Devtools can be opened with the usual Cmd/Ctrl-Shift-I. | ||||||
|  |  | ||||||
| @ -128,18 +128,7 @@ Before you submit a contribution PR to this repo, please ensure that: | |||||||
|  |  | ||||||
| ## Release a new version | ## Release a new version | ||||||
|  |  | ||||||
| #### 1. Bump the versions by running `./make-release.sh` | #### 1. Bump the versions by running `./make-release.sh` and create a Cut Release PR | ||||||
|  |  | ||||||
| The `./make-release.sh` script has git commands to pull main but to be sure you can run the following git commands to have a fresh `main` locally. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| git branch -D main |  | ||||||
| git checkout main |  | ||||||
| git pull origin |  | ||||||
| ./make-release.sh |  | ||||||
| # Copy within the back ticks and paste the stdout of the change log |  | ||||||
| git push --set-upstream origin <branch name created from ./make-release.sh> |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| That will create the branch with the updated json files for you: | That will create the branch with the updated json files for you: | ||||||
| - run `./make-release.sh` or `./make-release.sh patch` for a patch update; | - run `./make-release.sh` or `./make-release.sh patch` for a patch update; | ||||||
| @ -148,32 +137,28 @@ That will create the branch with the updated json files for you: | |||||||
|  |  | ||||||
| After it runs you should just need the push the branch and open a PR. | After it runs you should just need the push the branch and open a PR. | ||||||
|  |  | ||||||
| #### 2. Create a Cut Release PR | **Important:** It needs to be prefixed with `Cut release v` to build in release mode and a few other things to test in the best context possible, the intent would be for instance to have `Cut release v1.2.3` for the `v1.2.3` release candidate. | ||||||
|  |  | ||||||
| When you open the PR copy the change log from the output of the `./make-release.sh` script into the description of the PR. |  | ||||||
|  |  | ||||||
| **Important:** Pull request title needs to be prefixed with `Cut release v` to build in release mode and a few other things to test in the best context possible, the intent would be for instance to have `Cut release v1.2.3` for the `v1.2.3` release candidate. |  | ||||||
|  |  | ||||||
| The PR may then serve as a place to discuss the human-readable changelog and extra QA. The `make-release.sh` tool suggests a changelog for you too to be used as PR description, just make sure to delete lines that are not user facing. | The PR may then serve as a place to discuss the human-readable changelog and extra QA. The `make-release.sh` tool suggests a changelog for you too to be used as PR description, just make sure to delete lines that are not user facing. | ||||||
|  |  | ||||||
| #### 3. Manually test artifacts from the Cut Release PR | #### 2. Smoke test artifacts from the Cut Release PR | ||||||
|  |  | ||||||
| The release builds can be find under the `artifact` zip, at the very bottom of the `ci` action page for each commit on this branch. | The release builds can be find under the `artifact` zip, at the very bottom of the `ci` action page for each commit on this branch. | ||||||
|  |  | ||||||
| Manually test against this [list](https://github.com/KittyCAD/modeling-app/issues/3588) across Windows, MacOS, Linux and posting results as comments in the Cut Release PR. | We don't have a strict process, but click around and check for anything obvious, posting results as comments in the Cut Release PR. | ||||||
|  |  | ||||||
| The other `ci` output in Cut Release PRs is `updater-test`, because we don't have a way to test this fully automated, we have a semi-automated process. Download updater-test zip file, install the app, run it, expect an updater prompt to a dummy v0.99.99, install it and check that the app comes back at that version (on both macOS and Windows). | The other `ci` output in Cut Release PRs is `updater-test`, because we don't have a way to test this fully automated, we have a semi-automated process. Download updater-test zip file, install the app, run it, expect an updater prompt to a dummy v0.99.99, install it and check that the app comes back at that version (on both macOS and Windows). | ||||||
|  |  | ||||||
| #### 4. Merge the Cut Release PR | #### 3. Merge the Cut Release PR | ||||||
|  |  | ||||||
| This will kick the `create-release` action, that creates a _Draft_ release out of this Cut Release PR merge after less than a minute, with the new version as title and Cut Release PR as description. | This will kick the `create-release` action, that creates a _Draft_ release out of this Cut Release PR merge after less than a minute, with the new version as title and Cut Release PR as description. | ||||||
|  |  | ||||||
|  |  | ||||||
| #### 5. Publish the release | #### 4. Publish the release | ||||||
|  |  | ||||||
| Head over to https://github.com/KittyCAD/modeling-app/releases, the draft release corresponding to the merged Cut Release PR should show up at the top as _Draft_. Click on it, verify the content, and hit _Publish_. | Head over to https://github.com/KittyCAD/modeling-app/releases, the draft release corresponding to the merged Cut Release PR should show up at the top as _Draft_. Click on it, verify the content, and hit _Publish_. | ||||||
|  |  | ||||||
| #### 6. Profit | #### 5. Profit | ||||||
|  |  | ||||||
| A new Action kicks in at https://github.com/KittyCAD/modeling-app/actions, which can be found under `release` event filter. | A new Action kicks in at https://github.com/KittyCAD/modeling-app/actions, which can be found under `release` event filter. | ||||||
|  |  | ||||||
| @ -319,7 +304,7 @@ yarn start | |||||||
| and finally: | and finally: | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| yarn test:unit | yarn test:nowatch | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| For individual testing: | For individual testing: | ||||||
| @ -334,81 +319,9 @@ Which will run our suite of [Vitest unit](https://vitest.dev/) and [React Testin | |||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| cd src/wasm-lib | cd src/wasm-lib | ||||||
| KITTYCAD_API_TOKEN=XXX cargo test -- --test-threads=1 | cargo test | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Where `XXX` is an API token from the production engine (NOT the dev environment). |  | ||||||
|  |  | ||||||
| We recommend using [nextest](https://nexte.st/) to run the Rust tests (its faster and is used in CI). Once installed, run the tests using |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| cd src/wasm-lib |  | ||||||
| KITTYCAD_API_TOKEN=XXX cargo run nextest |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Mapping CI CD jobs to local commands |  | ||||||
|  |  | ||||||
| When you see the CI CD fail on jobs you may wonder three things |  | ||||||
| - Do I have a bug in my code? |  | ||||||
| - Is the test flaky? |  | ||||||
| - Is there a bug in `main`? |  | ||||||
|  |  | ||||||
| To answer these questions the following commands will give you confidence to locate the issue. |  | ||||||
|  |  | ||||||
| #### Static Analysis |  | ||||||
|  |  | ||||||
| Part of the CI CD pipeline performs static analysis on the code. Use the following commands to mimic the CI CD jobs. |  | ||||||
|  |  | ||||||
| The following set of commands should get us closer to one and done commands to instantly retest issues. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| yarn test-setup |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| > Gotcha, are packages up to date and is the wasm built? |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| yarn tsc |  | ||||||
| yarn fmt-check |  | ||||||
| yarn lint |  | ||||||
| yarn test:unit:local |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| > Gotcha: Our unit tests have integration tests in them. You need to run a localhost server to run the unit tests. |  | ||||||
|  |  | ||||||
| #### E2E Tests |  | ||||||
|  |  | ||||||
| **Playwright Browser** |  | ||||||
|  |  | ||||||
| These E2E tests run in a browser (without electron). |  | ||||||
| There are tests that are skipped if they are ran in a windows OS or Linux OS. We can use playwright tags to implement test skipping. |  | ||||||
|  |  | ||||||
| Breaking down the command `yarn test:playwright:browser:chrome:windows` |  | ||||||
| - The application is `playwright` |  | ||||||
| - The runtime is a `browser` |  | ||||||
| - The specific `browser` is `chrome` |  | ||||||
| - The test should run in a `windows` environment. It will skip tests that are broken or flaky in the windows OS. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| yarn test:playwright:browser:chrome |  | ||||||
| yarn test:playwright:browser:chrome:windows |  | ||||||
| yarn test:playwright:browser:chrome:ubuntu |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| **Playwright Electron** |  | ||||||
|  |  | ||||||
| These E2E tests run in electron. There are tests that are skipped if they are ran in a windows, linux, or macos environment. We can use playwright tags to implement test skipping. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| yarn test:playwright:electron:local |  | ||||||
| yarn test:playwright:electron:windows:local |  | ||||||
| yarn test:playwright:electron:macos:local |  | ||||||
| yarn test:playwright:electron:ubuntu:local |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| > Why does it say local? The CI CD commands that run in the pipeline cannot be ran locally. A single command will not properly setup the testing environment locally. |  | ||||||
|  |  | ||||||
| #### Some notes on CI | #### Some notes on CI | ||||||
|  |  | ||||||
| The tests are broken into snapshot tests and non-snapshot tests, and they run in that order, they automatically commit new snap shots, so if you see an image commit check it was an intended change. If we have non-determinism in the snapshots such that they are always committing new images, hopefully this annoyance makes us fix them asap, if you notice this happening let Kurt know. But for the odd occasion `git reset --hard HEAD~ && git push -f` is your friend. | The tests are broken into snapshot tests and non-snapshot tests, and they run in that order, they automatically commit new snap shots, so if you see an image commit check it was an intended change. If we have non-determinism in the snapshots such that they are always committing new images, hopefully this annoyance makes us fix them asap, if you notice this happening let Kurt know. But for the odd occasion `git reset --hard HEAD~ && git push -f` is your friend. | ||||||
| @ -438,6 +351,25 @@ PS: for the debug panel, the following JSON is useful for snapping the camera | |||||||
|  |  | ||||||
| </details> | </details> | ||||||
|  |  | ||||||
|  | ### Tauri e2e tests | ||||||
|  |  | ||||||
|  | #### Windows (local only until the CI edge version mismatch is fixed) | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | yarn install | ||||||
|  | yarn build:wasm-dev | ||||||
|  | cp src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||||
|  | yarn vite build --mode development | ||||||
|  | yarn tauri build --debug -b | ||||||
|  | $env:KITTYCAD_API_TOKEN="<YOUR_KITTYCAD_API_TOKEN>" | ||||||
|  | $env:VITE_KC_API_BASE_URL="https://api.dev.zoo.dev" | ||||||
|  | $env:E2E_TAURI_ENABLED="true" | ||||||
|  | $env:TS_NODE_COMPILER_OPTIONS='{"module": "commonjs"}' | ||||||
|  | $env:E2E_APPLICATION=".\src-tauri\target\debug\Zoo Modeling App.exe" | ||||||
|  | Stop-Process -Name msedgedriver | ||||||
|  | yarn wdio run wdio.conf.ts | ||||||
|  | ``` | ||||||
|  |  | ||||||
| ## KCL | ## KCL | ||||||
|  |  | ||||||
| For how to contribute to KCL, [see our KCL README](https://github.com/KittyCAD/modeling-app/tree/main/src/wasm-lib/kcl). | For how to contribute to KCL, [see our KCL README](https://github.com/KittyCAD/modeling-app/tree/main/src/wasm-lib/kcl). | ||||||
|  | |||||||
							
								
								
									
										24
									
								
								add-osx-cert.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								add-osx-cert.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,24 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  | # From https://dev.to/rwwagner90/signing-electron-apps-with-github-actions-4cof | ||||||
|  |  | ||||||
|  | KEY_CHAIN=build.keychain | ||||||
|  | CERTIFICATE_P12=certificate.p12 | ||||||
|  |  | ||||||
|  | # Recreate the certificate from the secure environment variable | ||||||
|  | echo $APPLE_CERTIFICATE | base64 --decode > $CERTIFICATE_P12 | ||||||
|  |  | ||||||
|  | #create a keychain | ||||||
|  | security create-keychain -p actions $KEY_CHAIN | ||||||
|  |  | ||||||
|  | # Make the keychain the default so identities are found | ||||||
|  | security default-keychain -s $KEY_CHAIN | ||||||
|  |  | ||||||
|  | # Unlock the keychain | ||||||
|  | security unlock-keychain -p actions $KEY_CHAIN | ||||||
|  |  | ||||||
|  | security import $CERTIFICATE_P12 -k $KEY_CHAIN -P $APPLE_CERTIFICATE_PASSWORD -T /usr/bin/codesign; | ||||||
|  |  | ||||||
|  | security set-key-partition-list -S apple-tool:,apple: -s -k actions $KEY_CHAIN | ||||||
|  |  | ||||||
|  | # remove certs | ||||||
|  | rm -fr *.p12 | ||||||
| @ -22,3 +22,8 @@ once fixed in engine will just start working here with no language changes. | |||||||
|  |  | ||||||
| - **Chamfers**: Chamfers cannot intersect, you will get an error. Only simple | - **Chamfers**: Chamfers cannot intersect, you will get an error. Only simple | ||||||
|     chamfer cases work currently. |     chamfer cases work currently. | ||||||
|  |  | ||||||
|  |     Sketching on the chamfered face does not currently work. | ||||||
|  |  | ||||||
|  | - **Shell**: Shell sometimes does not work when arcs or fillets are involved. | ||||||
|  |     We are tracking the engine side bug on this. | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										877
									
								
								docs/kcl/arc.md
									
									
									
									
									
								
							
							
						
						
									
										877
									
								
								docs/kcl/arc.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1029
									
								
								docs/kcl/circle.md
									
									
									
									
									
								
							
							
						
						
									
										1029
									
								
								docs/kcl/circle.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1270
									
								
								docs/kcl/hole.md
									
									
									
									
									
								
							
							
						
						
									
										1270
									
								
								docs/kcl/hole.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -56,17 +56,13 @@ layout: manual | |||||||
| * [`line`](kcl/line) | * [`line`](kcl/line) | ||||||
| * [`lineTo`](kcl/lineTo) | * [`lineTo`](kcl/lineTo) | ||||||
| * [`ln`](kcl/ln) | * [`ln`](kcl/ln) | ||||||
| * [`loft`](kcl/loft) |  | ||||||
| * [`log`](kcl/log) | * [`log`](kcl/log) | ||||||
| * [`log10`](kcl/log10) | * [`log10`](kcl/log10) | ||||||
| * [`log2`](kcl/log2) | * [`log2`](kcl/log2) | ||||||
| * [`m`](kcl/m) | * [`m`](kcl/m) | ||||||
| * [`map`](kcl/map) |  | ||||||
| * [`max`](kcl/max) | * [`max`](kcl/max) | ||||||
| * [`min`](kcl/min) | * [`min`](kcl/min) | ||||||
| * [`mirror2d`](kcl/mirror2d) |  | ||||||
| * [`mm`](kcl/mm) | * [`mm`](kcl/mm) | ||||||
| * [`offsetPlane`](kcl/offsetPlane) |  | ||||||
| * [`patternCircular2d`](kcl/patternCircular2d) | * [`patternCircular2d`](kcl/patternCircular2d) | ||||||
| * [`patternCircular3d`](kcl/patternCircular3d) | * [`patternCircular3d`](kcl/patternCircular3d) | ||||||
| * [`patternLinear2d`](kcl/patternLinear2d) | * [`patternLinear2d`](kcl/patternLinear2d) | ||||||
| @ -78,8 +74,6 @@ layout: manual | |||||||
| * [`profileStart`](kcl/profileStart) | * [`profileStart`](kcl/profileStart) | ||||||
| * [`profileStartX`](kcl/profileStartX) | * [`profileStartX`](kcl/profileStartX) | ||||||
| * [`profileStartY`](kcl/profileStartY) | * [`profileStartY`](kcl/profileStartY) | ||||||
| * [`reduce`](kcl/reduce) |  | ||||||
| * [`rem`](kcl/rem) |  | ||||||
| * [`revolve`](kcl/revolve) | * [`revolve`](kcl/revolve) | ||||||
| * [`segAng`](kcl/segAng) | * [`segAng`](kcl/segAng) | ||||||
| * [`segEndX`](kcl/segEndX) | * [`segEndX`](kcl/segEndX) | ||||||
| @ -94,7 +88,6 @@ layout: manual | |||||||
| * [`tan`](kcl/tan) | * [`tan`](kcl/tan) | ||||||
| * [`tangentialArc`](kcl/tangentialArc) | * [`tangentialArc`](kcl/tangentialArc) | ||||||
| * [`tangentialArcTo`](kcl/tangentialArcTo) | * [`tangentialArcTo`](kcl/tangentialArcTo) | ||||||
| * [`tangentialArcToRelative`](kcl/tangentialArcToRelative) |  | ||||||
| * [`tau`](kcl/tau) | * [`tau`](kcl/tau) | ||||||
| * [`toDegrees`](kcl/toDegrees) | * [`toDegrees`](kcl/toDegrees) | ||||||
| * [`toRadians`](kcl/toRadians) | * [`toRadians`](kcl/toRadians) | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -16,23 +16,20 @@ legAngX(hypotenuse: number, leg: number) -> number | |||||||
|  |  | ||||||
| * `utilities` | * `utilities` | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Arguments |  | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `hypotenuse` | `number` |  | Yes | |  | ||||||
| | `leg` | `number` |  | Yes | |  | ||||||
|  |  | ||||||
| ### Returns |  | ||||||
|  |  | ||||||
| `number`  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Examples | ### Examples | ||||||
|  |  | ||||||
| ```js | ```js | ||||||
| legAngX(5, 3) | legAngX(5, 3) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### Arguments | ||||||
|  |  | ||||||
|  | * `hypotenuse`: `number` (REQUIRED) | ||||||
|  | * `leg`: `number` (REQUIRED) | ||||||
|  |  | ||||||
|  | ### Returns | ||||||
|  |  | ||||||
|  | `number` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -16,23 +16,20 @@ legAngY(hypotenuse: number, leg: number) -> number | |||||||
|  |  | ||||||
| * `utilities` | * `utilities` | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Arguments |  | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `hypotenuse` | `number` |  | Yes | |  | ||||||
| | `leg` | `number` |  | Yes | |  | ||||||
|  |  | ||||||
| ### Returns |  | ||||||
|  |  | ||||||
| `number`  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Examples | ### Examples | ||||||
|  |  | ||||||
| ```js | ```js | ||||||
| legAngY(5, 3) | legAngY(5, 3) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### Arguments | ||||||
|  |  | ||||||
|  | * `hypotenuse`: `number` (REQUIRED) | ||||||
|  | * `leg`: `number` (REQUIRED) | ||||||
|  |  | ||||||
|  | ### Returns | ||||||
|  |  | ||||||
|  | `number` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -16,23 +16,20 @@ legLen(hypotenuse: number, leg: number) -> number | |||||||
|  |  | ||||||
| * `utilities` | * `utilities` | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Arguments |  | ||||||
|  |  | ||||||
| | Name | Type | Description | Required | |  | ||||||
| |----------|------|-------------|----------| |  | ||||||
| | `hypotenuse` | `number` |  | Yes | |  | ||||||
| | `leg` | `number` |  | Yes | |  | ||||||
|  |  | ||||||
| ### Returns |  | ||||||
|  |  | ||||||
| `number`  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Examples | ### Examples | ||||||
|  |  | ||||||
| ```js | ```js | ||||||
| legLen(5, 3) | legLen(5, 3) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### Arguments | ||||||
|  |  | ||||||
|  | * `hypotenuse`: `number` (REQUIRED) | ||||||
|  | * `leg`: `number` (REQUIRED) | ||||||
|  |  | ||||||
|  | ### Returns | ||||||
|  |  | ||||||
|  | `number` | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										861
									
								
								docs/kcl/line.md
									
									
									
									
									
								
							
							
						
						
									
										861
									
								
								docs/kcl/line.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										116
									
								
								docs/kcl/loft.md
									
									
									
									
									
								
							
							
						
						
									
										116
									
								
								docs/kcl/loft.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1018
									
								
								docs/kcl/shell.md
									
									
									
									
									
								
							
							
						
						
									
										1018
									
								
								docs/kcl/shell.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	