Compare commits
	
		
			1 Commits
		
	
	
		
			pierremtb/
			...
			achalmers/
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e4b7830fd1 | 
| @ -1,3 +1,3 @@ | |||||||
| [codespell] | [codespell] | ||||||
| ignore-words-list: crate,everytime,inout,co-ordinate,ot,nwo,atleast,ue,afterall,ser | ignore-words-list: crate,everytime,inout,co-ordinate,ot,nwo,absolutey,atleast,ue,afterall | ||||||
| skip: **/target,node_modules,build,dist,./out,**/Cargo.lock,./docs/kcl/*.md,.yarn.lock,**/yarn.lock,./openapi/*.json,./packages/codemirror-lang-kcl/test/all.test.ts,tsconfig.tsbuildinfo | skip: **/target,node_modules,build,**/Cargo.lock,./docs/kcl/*.md,.yarn.lock,**/yarn.lock,./openapi/*.json,./src/lib/machine-api.d.ts | ||||||
|  | |||||||
| @ -2,8 +2,8 @@ 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_SITE_APP_URL=https://app.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! | # ONLY add your token in .env.development.local if you want to skip auth, otherwise this token takes precedence! | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| NODE_ENV=production |  | ||||||
| DEV=false |  | ||||||
| VITE_KC_API_WS_MODELING_URL=wss://api.zoo.dev/ws/modeling/commands | VITE_KC_API_WS_MODELING_URL=wss://api.zoo.dev/ws/modeling/commands | ||||||
| VITE_KC_API_BASE_URL=https://api.zoo.dev | VITE_KC_API_BASE_URL=https://api.zoo.dev | ||||||
| VITE_KC_SITE_BASE_URL=https://zoo.dev | VITE_KC_SITE_BASE_URL=https://zoo.dev | ||||||
| VITE_KC_SITE_APP_URL=https://app.zoo.dev |  | ||||||
| VITE_KC_SKIP_AUTH=false | VITE_KC_SKIP_AUTH=false | ||||||
| VITE_KC_CONNECTION_TIMEOUT_MS=15000 | VITE_KC_CONNECTION_TIMEOUT_MS=15000 | ||||||
|  | |||||||
							
								
								
									
										35
									
								
								.eslintrc
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								.eslintrc
									
									
									
									
									
								
							| @ -5,39 +5,16 @@ | |||||||
|     }, |     }, | ||||||
|     "plugins": [ |     "plugins": [ | ||||||
|       "css-modules", |       "css-modules", | ||||||
|       "jest", |  | ||||||
|       "jsx-a11y", |  | ||||||
|       "react", |  | ||||||
|       "react-hooks", |  | ||||||
|       "suggest-no-throw", |       "suggest-no-throw", | ||||||
|       "testing-library", |  | ||||||
|       "@typescript-eslint" |  | ||||||
|     ], |     ], | ||||||
|     "extends": [ |     "extends": [ | ||||||
|       "plugin:css-modules/recommended", |       "react-app", | ||||||
|       "plugin:jsx-a11y/recommended", |       "react-app/jest", | ||||||
|       "plugin:react-hooks/recommended" |       "plugin:css-modules/recommended" | ||||||
|     ], |     ], | ||||||
|     "rules": { |     "rules": { | ||||||
|       "@typescript-eslint/no-floating-promises": "error", |       "@typescript-eslint/no-floating-promises": "error", | ||||||
|       "@typescript-eslint/no-misused-promises": "error", |       "@typescript-eslint/no-misused-promises": "error", | ||||||
|       "jsx-a11y/click-events-have-key-events": "off", |  | ||||||
|       "jsx-a11y/no-autofocus": "off", |  | ||||||
|       "jsx-a11y/no-noninteractive-element-interactions": "off", |  | ||||||
|       "no-restricted-globals": [ |  | ||||||
|         "error", |  | ||||||
|         { |  | ||||||
|           "name": "isNaN", |  | ||||||
|           "message": "Use Number.isNaN() instead." |  | ||||||
|         }, |  | ||||||
|       ], |  | ||||||
|       "no-restricted-syntax": [ |  | ||||||
|         "error", |  | ||||||
|         { |  | ||||||
|           "selector": "CallExpression[callee.object.name='Array'][callee.property.name='isArray']", |  | ||||||
|           "message": "Use isArray() in lib/utils.ts instead of Array.isArray()." |  | ||||||
|         } |  | ||||||
|       ], |  | ||||||
|       "semi": [ |       "semi": [ | ||||||
|         "error", |         "error", | ||||||
|         "never" |         "never" | ||||||
| @ -48,9 +25,6 @@ | |||||||
|     "overrides": [ |     "overrides": [ | ||||||
|       { |       { | ||||||
|         "files": ["e2e/**/*.ts"], // Update the pattern based on your file structure |         "files": ["e2e/**/*.ts"], // Update the pattern based on your file structure | ||||||
|         "extends": [ |  | ||||||
|           "plugin:testing-library/react" |  | ||||||
|         ], |  | ||||||
|         "rules": { |         "rules": { | ||||||
|           "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", | ||||||
| @ -59,9 +33,6 @@ | |||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         "files": ["src/**/*.test.ts"], |         "files": ["src/**/*.test.ts"], | ||||||
|         "extends": [ |  | ||||||
|           "plugin:testing-library/react" |  | ||||||
|         ], |  | ||||||
|         "rules": { |         "rules": { | ||||||
|           "suggest-no-throw/suggest-no-throw": "off", |           "suggest-no-throw/suggest-no-throw": "off", | ||||||
|         } |         } | ||||||
|  | |||||||
							
								
								
									
										59
									
								
								.github/ci-cd-scripts/playwright-browser-chrome.sh
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										59
									
								
								.github/ci-cd-scripts/playwright-browser-chrome.sh
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @ -0,0 +1,59 @@ | |||||||
|  | # 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 | ||||||
							
								
								
									
										22
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								.github/ci-cd-scripts/playwright-electron.sh
									
									
									
									
										vendored
									
									
								
							| @ -1,17 +1,15 @@ | |||||||
| #!/bin/bash |  | ||||||
|  |  | ||||||
| # bash strict mode | # bash strict mode | ||||||
| set -euo pipefail | set -euo pipefail | ||||||
|  |  | ||||||
| if [[ ! -f "test-results/.last-run.json" ]]; then | if [[ ! -f "test-results/.last-run.json" ]]; then | ||||||
|     # if no last run artifact, than run plawright normally |     # if no last run artifact, than run plawright normally | ||||||
|     echo "run playwright normally" |     echo "run playwright normally" | ||||||
|         if [[ "$3" == *ubuntu* ]]; then |         if [[ "$1" == ubuntu-latest* ]]; then | ||||||
|             xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu -- --shard=$1/$2 || true |             xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu || true | ||||||
|         elif [[ "$3" == *windows* ]]; then |         elif [[ "$1" == windows-latest* ]]; then | ||||||
|             yarn test:playwright:electron:windows -- --shard=$1/$2 || true |             yarn test:playwright:electron:windows || true | ||||||
|         elif [[ "$3" == *macos* ]]; then |         elif [[ "$1" == macos-14* ]]; then | ||||||
|             yarn test:playwright:electron:macos  -- --shard=$1/$2 || true |             yarn test:playwright:electron:macos || true | ||||||
|         else |         else | ||||||
|             echo "Do not run playwright. Unable to detect os runtime." |             echo "Do not run playwright. Unable to detect os runtime." | ||||||
|             exit 1 |             exit 1 | ||||||
| @ -21,7 +19,7 @@ if [[ ! -f "test-results/.last-run.json" ]]; then | |||||||
| fi | fi | ||||||
|  |  | ||||||
| retry=1 | retry=1 | ||||||
| max_retrys=5 | max_retrys=4 | ||||||
|  |  | ||||||
| # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | # retry failed tests, doing our own retries because using inbuilt playwright retries causes connection issues | ||||||
| while [[ $retry -le $max_retrys ]]; do | while [[ $retry -le $max_retrys ]]; do | ||||||
| @ -30,11 +28,11 @@ while [[ $retry -le $max_retrys ]]; do | |||||||
|         if [[ $failed_tests -gt 0 ]]; then |         if [[ $failed_tests -gt 0 ]]; then | ||||||
|             echo "retried=true" >>$GITHUB_OUTPUT |             echo "retried=true" >>$GITHUB_OUTPUT | ||||||
|             echo "run playwright with last failed tests and retry $retry" |             echo "run playwright with last failed tests and retry $retry" | ||||||
|             if [[ "$3" == *ubuntu* ]]; then |             if [[ "$1" == ubuntu-latest* ]]; then | ||||||
|                 xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu -- --last-failed || true |                 xvfb-run --auto-servernum --server-args="-screen 0 1280x960x24" -- yarn test:playwright:electron:ubuntu -- --last-failed || true | ||||||
|             elif [[ "$3" == *windows* ]]; then |             elif [[ "$1" == windows-latest* ]]; then | ||||||
|                 yarn test:playwright:electron:windows -- --last-failed || true |                 yarn test:playwright:electron:windows -- --last-failed || true | ||||||
|             elif [[ "$3" == *macos* ]]; then |             elif [[ "$1" == macos-14* ]]; then | ||||||
|                 yarn test:playwright:electron:macos -- --last-failed || true |                 yarn test:playwright:electron:macos -- --last-failed || true | ||||||
|             else |             else | ||||||
|                 echo "Do not run playwright. Unable to detect os runtime." |                 echo "Do not run playwright. Unable to detect os runtime." | ||||||
|  | |||||||
							
								
								
									
										55
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										55
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
								
							| @ -5,37 +5,24 @@ | |||||||
|  |  | ||||||
| version: 2 | version: 2 | ||||||
| updates: | updates: | ||||||
|   - package-ecosystem: 'npm' # See documentation for possible values |     - package-ecosystem: 'npm' # See documentation for possible values | ||||||
|     directories: |       directory: '/' # Location of package manifests | ||||||
|       - '/' |       schedule: | ||||||
|       - '/packages/codemirror-lang-kcl/' |           interval: 'daily' | ||||||
|       - '/packages/codemirror-lsp-client/' |       reviewers: | ||||||
|     schedule: |           - franknoirot | ||||||
|       interval: weekly |           - irev-dev | ||||||
|       day: monday |     - package-ecosystem: 'github-actions' # See documentation for possible values | ||||||
|     reviewers: |       directory: '/' # Location of package manifests | ||||||
|       - franknoirot |       schedule: | ||||||
|       - irev-dev |           interval: 'daily' | ||||||
|   - package-ecosystem: 'github-actions' # See documentation for possible values |       reviewers: | ||||||
|     directory: '/' # Location of package manifests |           - adamchalmers | ||||||
|     schedule: |           - jessfraz | ||||||
|       interval: weekly |     - package-ecosystem: 'cargo' # See documentation for possible values | ||||||
|       day: monday |       directory: '/src/wasm-lib/' # Location of package manifests | ||||||
|     reviewers: |       schedule: | ||||||
|       - adamchalmers |           interval: 'daily' | ||||||
|       - jessfraz |       reviewers: | ||||||
|   - package-ecosystem: 'cargo' # See documentation for possible values |           - adamchalmers | ||||||
|     directory: '/src/wasm-lib/' # Location of package manifests |           - jessfraz | ||||||
|     schedule: |  | ||||||
|       interval: weekly |  | ||||||
|       day: monday |  | ||||||
|     reviewers: |  | ||||||
|       - adamchalmers |  | ||||||
|       - jessfraz |  | ||||||
|     groups: |  | ||||||
|       serde-dependencies: |  | ||||||
|         patterns: |  | ||||||
|           - "serde*" |  | ||||||
|       wasm-bindgen-deps: |  | ||||||
|         patterns: |  | ||||||
|           - "wasm-bindgen*" |  | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/build-and-store-wasm.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-and-store-wasm.yml
									
									
									
									
										vendored
									
									
								
							| @ -27,7 +27,7 @@ jobs: | |||||||
|  |  | ||||||
|  |  | ||||||
|       # Upload the WASM bundle as an artifact |       # Upload the WASM bundle as an artifact | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: wasm-bundle |           name: wasm-bundle | ||||||
|           path: src/wasm-lib/pkg |           path: src/wasm-lib/pkg | ||||||
|  | |||||||
| @ -1,20 +1,21 @@ | |||||||
| name: build-apps | name: build-publish-apps | ||||||
| 
 | 
 | ||||||
| on: | on: | ||||||
|   pull_request: |   pull_request: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|     tags: |   release: | ||||||
|       - 'v[0-9]+.[0-9]+.[0-9]+' |     types: [published] | ||||||
|   schedule: |   schedule: | ||||||
|     - cron: '0 4 * * *' |     - cron: '0 4 * * *' | ||||||
|   # Daily at 04:00 AM UTC |   # Daily at 04:00 AM UTC | ||||||
|   # Will checkout the last commit from the default branch (main as of 2023-10-04) |   # Will checkout the last commit from the default branch (main as of 2023-10-04) | ||||||
| 
 | 
 | ||||||
| env: | env: | ||||||
|   IS_RELEASE: ${{ github.ref_type == 'tag' }} |   CUT_RELEASE_PR: ${{ github.event_name == 'pull_request' && (contains(github.event.pull_request.title, 'Cut release v')) }} | ||||||
|   IS_NIGHTLY: ${{ github.event_name == 'schedule' }} |   BUILD_RELEASE: ${{ github.event_name == 'release' || github.event_name == 'schedule' || github.event_name == 'pull_request' && (contains(github.event.pull_request.title, 'Cut release v')) }} | ||||||
|  |   NOTES: ${{ github.event_name == 'release' && github.event.release.body || format('Non-release build, commit {0}', github.sha) }} | ||||||
| 
 | 
 | ||||||
| concurrency: | concurrency: | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
| @ -25,7 +26,6 @@ jobs: | |||||||
|     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_notes.outputs.notes }} |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
| @ -47,40 +47,48 @@ jobs: | |||||||
|       - name: Run build:wasm |       - name: Run build:wasm | ||||||
|         run: "yarn build:wasm" |         run: "yarn build:wasm" | ||||||
| 
 | 
 | ||||||
|       - name: Set nightly version, product name, release notes, and icons |       - name: Set nightly version | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         if: github.event_name == 'schedule' | ||||||
|         run: yarn files:flip-to-nightly |  | ||||||
| 
 |  | ||||||
|       - name: Set release version |  | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |  | ||||||
|         run: | |         run: | | ||||||
|           export VERSION=${GITHUB_REF_NAME#v} |           VERSION=$(date +'%-y.%-m.%-d') yarn bump-jsons | ||||||
|           yarn files:set-version |  | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       # TODO: see if we need to inject updater nightly URL here https://dl.zoo.dev/releases/modeling-app/nightly/last_update.json | ||||||
|  | 
 | ||||||
|  |       - name: Generate release notes | ||||||
|  |         run: | | ||||||
|  |           echo "$NOTES" > release-notes.md | ||||||
|  |           cat release-notes.md | ||||||
|  | 
 | ||||||
|  |       - uses: actions/upload-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: prepared-files |           name: prepared-files | ||||||
|           path: | |           path: | | ||||||
|             package.json |             package.json | ||||||
|             electron-builder.yml |  | ||||||
|             src/wasm-lib/pkg/wasm_lib* |             src/wasm-lib/pkg/wasm_lib* | ||||||
|             release-notes.md |             release-notes.md | ||||||
|             assets/icon.ico |  | ||||||
|             assets/icon.png |  | ||||||
| 
 | 
 | ||||||
|       - id: export_version |       - id: export_version | ||||||
|         run: echo "version=`cat package.json | jq -r '.version'`" >> "$GITHUB_OUTPUT" |         run: echo "version=`cat package.json | jq -r '.version'`" >> "$GITHUB_OUTPUT" | ||||||
| 
 | 
 | ||||||
|       - id: export_notes |       - name: Prepare electron-builder.yml file for nightly | ||||||
|         run: echo "notes=`cat release-notes.md`" >> "$GITHUB_OUTPUT" |         if: ${{ github.event_name == 'schedule' }} | ||||||
|  |         run: | | ||||||
|  |           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/nightly"' electron-builder.yml | ||||||
|  | 
 | ||||||
|  |       - uses: actions/upload-artifact@v3 | ||||||
|  |         if: ${{ github.event_name == 'schedule' }} | ||||||
|  |         with: | ||||||
|  |           name: prepared-files-nightly | ||||||
|  |           path: | | ||||||
|  |             electron-builder.yml | ||||||
| 
 | 
 | ||||||
|       - name: Prepare electron-builder.yml file for updater test |       - name: Prepare electron-builder.yml file for updater test | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/updater-test"' electron-builder.yml |           yq -i '.publish[0].url = "https://dl.zoo.dev/releases/modeling-app/updater-test"' electron-builder.yml | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: prepared-files-updater-test |           name: prepared-files-updater-test | ||||||
|           path: | |           path: | | ||||||
| @ -101,24 +109,32 @@ jobs: | |||||||
|             platform: linux |             platform: linux | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     env: |     env: | ||||||
|  |       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 }} |       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         name: prepared-files |         name: prepared-files | ||||||
| 
 | 
 | ||||||
|       - name: Copy prepared files |       - name: Copy prepared files | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-files |           ls -R prepared-files | ||||||
|           cp prepared-files/package.json package.json |           cp prepared-files/package.json package.json | ||||||
|           cp prepared-files/electron-builder.yml electron-builder.yml |  | ||||||
|           cp prepared-files/src/wasm-lib/pkg/wasm_lib_bg.wasm public |           cp prepared-files/src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||||
|           mkdir src/wasm-lib/pkg |           mkdir src/wasm-lib/pkg | ||||||
|           cp prepared-files/src/wasm-lib/pkg/wasm_lib* 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 |           cp prepared-files/release-notes.md release-notes.md | ||||||
|           cp prepared-files/assets/icon.ico assets/icon.ico | 
 | ||||||
|           cp prepared-files/assets/icon.png assets/icon.png |       - uses: actions/download-artifact@v3 | ||||||
|  |         if: ${{ github.event_name == 'schedule' }} | ||||||
|  |         name: prepared-files-nightly | ||||||
|  | 
 | ||||||
|  |       - name: Copy updated electron-builder.yml file for nightly build | ||||||
|  |         if: ${{ github.event_name == 'schedule' }} | ||||||
|  |         run: | | ||||||
|  |           ls -R prepared-files-nightly | ||||||
|  |           cp prepared-files-nightly/electron-builder.yml electron-builder.yml | ||||||
| 
 | 
 | ||||||
|       - name: Sync node version and setup cache |       - name: Sync node version and setup cache | ||||||
|         uses: actions/setup-node@v4 |         uses: actions/setup-node@v4 | ||||||
| @ -126,16 +142,12 @@ jobs: | |||||||
|           node-version-file: '.nvmrc' |           node-version-file: '.nvmrc' | ||||||
|           cache: 'yarn' # Set this to npm, yarn or pnpm. |           cache: 'yarn' # Set this to npm, yarn or pnpm. | ||||||
| 
 | 
 | ||||||
|       - name: yarn install |       - run: yarn install | ||||||
|         # Windows is picky sometimes and fails on fetch. Step takes about ~30s | 
 | ||||||
|         uses: nick-fields/retry@v3.0.0 |       - run: yarn tronb:vite | ||||||
|         with: |  | ||||||
|           timeout_minutes: 2 |  | ||||||
|           max_attempts: 3 |  | ||||||
|           command: yarn install |  | ||||||
| 
 | 
 | ||||||
|       - name: Prepare certificate and variables (Windows only) |       - name: Prepare certificate and variables (Windows only) | ||||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} |         if: ${{ env.BUILD_RELEASE == 'true' && matrix.os == 'windows-2022' }} | ||||||
|         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 | ||||||
| @ -150,7 +162,7 @@ jobs: | |||||||
|         shell: bash |         shell: bash | ||||||
| 
 | 
 | ||||||
|       - name: Setup certicate with SSM KSP (Windows only) |       - name: Setup certicate with SSM KSP (Windows only) | ||||||
|         if: ${{ (env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true') && matrix.os == 'windows-2022' }} |         if: ${{ env.BUILD_RELEASE == 'true' && matrix.os == 'windows-2022' }} | ||||||
|         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 | ||||||
| @ -161,13 +173,13 @@ jobs: | |||||||
|         shell: cmd |         shell: cmd | ||||||
| 
 | 
 | ||||||
|       - name: Build the app (debug) |       - name: Build the app (debug) | ||||||
|         if: ${{ env.IS_RELEASE == 'false' && env.IS_NIGHTLY == 'false' }} |         if: ${{ env.BUILD_RELEASE == 'false' }} | ||||||
|         # electron-builder doesn't have a concept of release vs debug, |         # electron-builder doesn't have a concept of release vs debug, | ||||||
|         # this is just not doing any codesign or release yml generation, and points to dev infra |         # this is just not doing any codesign or release yml generation | ||||||
|         run: yarn tronb:package:dev |         run: yarn electron-builder --config | ||||||
| 
 | 
 | ||||||
|       - name: Build the app (release) |       - name: Build the app (release) | ||||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} |         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||||
|         env: |         env: | ||||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} |           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} |           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||||
| @ -176,19 +188,14 @@ jobs: | |||||||
|           CSC_LINK: ${{ secrets.APPLE_CERTIFICATE }} |           CSC_LINK: ${{ secrets.APPLE_CERTIFICATE }} | ||||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} |           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} |           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||||
|  |           CSC_FOR_PULL_REQUEST: true | ||||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} |           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||||
|           DEBUG: "electron-notarize*" |         run: yarn electron-builder --config --publish always | ||||||
|         # TODO: Fix electron-notarize flakes. The logs above should help gather more data on failures |  | ||||||
|         uses: nick-fields/retry@v3.0.0 |  | ||||||
|         with: |  | ||||||
|           timeout_minutes: 10 |  | ||||||
|           max_attempts: 3 |  | ||||||
|           command: yarn tronb:package:prod |  | ||||||
| 
 | 
 | ||||||
|       - name: List artifacts in out/ |       - name: List artifacts in out/ | ||||||
|         run: ls -R out |         run: ls -R out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-${{ matrix.platform }} |           name: out-arm64-${{ matrix.platform }} | ||||||
|           # first two will pick both Zoo Modeling App-$VERSION-arm64-win.exe and Zoo Modeling App-$VERSION-win.exe |           # first two will pick both Zoo Modeling App-$VERSION-arm64-win.exe and Zoo Modeling App-$VERSION-win.exe | ||||||
| @ -198,7 +205,7 @@ jobs: | |||||||
|             out/*-arm64-mac.* |             out/*-arm64-mac.* | ||||||
|             out/*-arm64-linux.* |             out/*-arm64-linux.* | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-${{ matrix.platform }} |           name: out-x64-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
| @ -206,29 +213,27 @@ jobs: | |||||||
|             out/*-x64-mac.* |             out/*-x64-mac.* | ||||||
|             out/*-x86_64-linux.* |             out/*-x86_64-linux.* | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         if: ${{ env.IS_RELEASE == 'true' || env.IS_NIGHTLY == 'true' }} |         if: ${{ env.BUILD_RELEASE == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: out-yml-${{ matrix.platform }} |           name: out-yml | ||||||
|           path: | |           path: | | ||||||
|             out/latest*.yml |             out/latest*.yml | ||||||
| 
 | 
 | ||||||
|       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back |       # TODO: add the 'Build for Mac TestFlight (nightly)' stage back | ||||||
| 
 | 
 | ||||||
|       # The steps below are for updater-test builds, only on release |       - uses: actions/download-artifact@v3 | ||||||
| 
 |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |  | ||||||
|         name: prepared-files-updater-test |         name: prepared-files-updater-test | ||||||
| 
 | 
 | ||||||
|       - name: Copy updated electron-builder.yml file for updater test |       - name: Copy updated electron-builder.yml file for updater test | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|         run: | |         run: | | ||||||
|           ls -R prepared-files-updater-test |           ls -R prepared-files-updater-test | ||||||
|           cp prepared-files-updater-test/electron-builder.yml electron-builder.yml |           cp prepared-files-updater-test/electron-builder.yml electron-builder.yml | ||||||
| 
 | 
 | ||||||
|       - name: Build the app (updater-test) |       - name: Build the app (updater-test) | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|         env: |         env: | ||||||
|           APPLE_ID: ${{ secrets.APPLE_ID }} |           APPLE_ID: ${{ secrets.APPLE_ID }} | ||||||
|           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} |           APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} | ||||||
| @ -237,17 +242,12 @@ jobs: | |||||||
|           CSC_LINK: ${{ secrets.APPLE_CERTIFICATE }} |           CSC_LINK: ${{ secrets.APPLE_CERTIFICATE }} | ||||||
|           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} |           CSC_KEY_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_PASSWORD }} | ||||||
|           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} |           CSC_KEYCHAIN: ${{ secrets.APPLE_SIGNING_IDENTITY }} | ||||||
|  |           CSC_FOR_PULL_REQUEST: true | ||||||
|           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} |           WINDOWS_CERTIFICATE_THUMBPRINT: ${{ secrets.WINDOWS_CERTIFICATE_THUMBPRINT }} | ||||||
|           DEBUG: "electron-notarize*" |         run: yarn electron-builder --config --publish always | ||||||
|         # TODO: Fix electron-notarize flakes. The logs above should help gather more data on failures |  | ||||||
|         uses: nick-fields/retry@v3.0.0 |  | ||||||
|         with: |  | ||||||
|           timeout_minutes: 10 |  | ||||||
|           max_attempts: 3 |  | ||||||
|           command: yarn tronb:package:prod |  | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: updater-test-arm64-${{ matrix.platform }} |           name: updater-test-arm64-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
| @ -255,8 +255,8 @@ jobs: | |||||||
|             out/*-arm64-mac.dmg |             out/*-arm64-mac.dmg | ||||||
|             out/*-arm64-linux.AppImage |             out/*-arm64-linux.AppImage | ||||||
| 
 | 
 | ||||||
|       - uses: actions/upload-artifact@v4 |       - uses: actions/upload-artifact@v3 | ||||||
|         if: ${{ env.IS_RELEASE == 'true' }} |         if: ${{ env.CUT_RELEASE_PR == 'true' }} | ||||||
|         with: |         with: | ||||||
|           name: updater-test-x64-${{ matrix.platform }} |           name: updater-test-x64-${{ matrix.platform }} | ||||||
|           path: | |           path: | | ||||||
| @ -265,69 +265,58 @@ jobs: | |||||||
|             out/*-x86_64-linux.AppImage |             out/*-x86_64-linux.AppImage | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|   upload-apps-release: |   publish-apps-release: | ||||||
|     runs-on: ubuntu-22.04 |     runs-on: ubuntu-22.04 | ||||||
|     permissions: |     permissions: | ||||||
|       contents: write |       contents: write | ||||||
|     if: ${{ github.ref_type == 'tag' || github.event_name == 'schedule' }} |     if: ${{ github.event_name == 'release' || github.event_name == 'schedule' }} | ||||||
|  |     needs: [prepare-files, build-apps] | ||||||
|     env: |     env: | ||||||
|       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} |       VERSION_NO_V: ${{ needs.prepare-files.outputs.version }} | ||||||
|       VERSION: ${{ format('v{0}', needs.prepare-files.outputs.version) }} |       VERSION: ${{ github.event_name == 'schedule' && needs.prepare-files.outputs.version || format('v{0}', needs.prepare-files.outputs.version) }} | ||||||
|     needs: [prepare-files, build-apps] |       PUB_DATE: ${{ github.event_name == 'release' && github.event.release.created_at || github.event.repository.updated_at }} | ||||||
|  |       BUCKET_DIR: ${{ github.event_name == 'schedule' && 'dl.kittycad.io/releases/modeling-app/nightly' || 'dl.kittycad.io/releases/modeling-app' }} | ||||||
|  |       WEBSITE_DIR: ${{ github.event_name == 'schedule' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} | ||||||
|  |       URL_CODED_NAME: ${{ github.event_name == 'schedule' && 'Zoo%20Modeling%20App%20%28Nightly%29' || 'Zoo%20Modeling%20App' }} | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v4 |       - uses: actions/checkout@v4 | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-win |           name: out-arm64-win | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-win |           name: out-x64-win | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |  | ||||||
|           name: out-yml-win |  | ||||||
|           path: out |  | ||||||
| 
 |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-mac |           name: out-arm64-mac | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-mac |           name: out-x64-mac | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |  | ||||||
|           name: out-yml-mac |  | ||||||
|           path: out |  | ||||||
| 
 |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |         with: | ||||||
|           name: out-arm64-linux |           name: out-arm64-linux | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-x64-linux |           name: out-x64-linux | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - uses: actions/download-artifact@v4 |       - uses: actions/download-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           name: out-yml-linux |           name: out-yml | ||||||
|           path: out |           path: out | ||||||
| 
 | 
 | ||||||
|       - name: Generate the download static endpoint |       - name: Generate the download static endpoint | ||||||
|         env: |  | ||||||
|           NOTES: ${{ needs.prepare-files.outputs.notes }} |  | ||||||
|           PUB_DATE: ${{ github.event.repository.updated_at }} |  | ||||||
|           WEBSITE_DIR: ${{ github.event_name == 'schedule' && 'dl.zoo.dev/releases/modeling-app/nightly' || 'dl.zoo.dev/releases/modeling-app' }} |  | ||||||
|           URL_CODED_NAME: ${{ github.event_name == 'schedule' && 'Zoo%20Modeling%20App%20%28Nightly%29' || 'Zoo%20Modeling%20App' }} |  | ||||||
|         run: | |         run: | | ||||||
|           RELEASE_DIR=https://${WEBSITE_DIR} |           RELEASE_DIR=https://${WEBSITE_DIR} | ||||||
|           jq --null-input \ |           jq --null-input \ | ||||||
| @ -364,60 +353,78 @@ jobs: | |||||||
|                   "url": $linux_x64_url |                   "url": $linux_x64_url | ||||||
|                 } |                 } | ||||||
|               } |               } | ||||||
|             }' > out/last_download.json |             }' > last_download.json | ||||||
|             cat out/last_download.json |             cat last_download.json | ||||||
| 
 |  | ||||||
|       - uses: actions/upload-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-download-json |  | ||||||
|           path: out/last_download.json |  | ||||||
| 
 | 
 | ||||||
|       - name: List artifacts |       - name: List artifacts | ||||||
|         run: "ls -R out" |         run: "ls -R out" | ||||||
| 
 | 
 | ||||||
|       - name: Set more complete nightly release notes |  | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |  | ||||||
|         run: | |  | ||||||
|           # Note: preferred going this way instead of a full clone in the checkout step, |  | ||||||
|           # see https://github.com/actions/checkout/issues/1471 |  | ||||||
|           git fetch --prune --unshallow --tags |  | ||||||
|           export TAG="nightly-${VERSION}" |  | ||||||
|           export PREVIOUS_TAG=$(git describe --tags --match="nightly-v[0-9]*" --abbrev=0) |  | ||||||
|           export NOTES=$(./scripts/get-nightly-changelog.sh) |  | ||||||
|           yarn files:set-notes |  | ||||||
| 
 |  | ||||||
|       - name: Authenticate to Google Cloud |       - name: Authenticate to Google Cloud | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         uses: 'google-github-actions/auth@v2.1.7' | ||||||
|         uses: 'google-github-actions/auth@v2.1.8' |  | ||||||
|         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 | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         uses: google-github-actions/setup-gcloud@v2.1.2 | ||||||
|         uses: google-github-actions/setup-gcloud@v2.1.4 |  | ||||||
|         with: |         with: | ||||||
|           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} |           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} | ||||||
| 
 | 
 | ||||||
|       - name: Upload nightly files to public bucket |       - name: Upload release files to public bucket | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         uses: google-github-actions/upload-cloud-storage@v2.2.0 | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.2 |  | ||||||
|         with: |         with: | ||||||
|           path: out |           path: out | ||||||
|           glob: '*' |           glob: 'Zoo*' | ||||||
|           parent: false |           parent: false | ||||||
|           destination: 'dl.kittycad.io/releases/modeling-app/nightly' |           destination: ${{ env.BUCKET_DIR }} | ||||||
|  | 
 | ||||||
|  |       - name: Upload update endpoint to public bucket | ||||||
|  |         uses: google-github-actions/upload-cloud-storage@v2.2.0 | ||||||
|  |         with: | ||||||
|  |           path: out | ||||||
|  |           glob: 'latest*' | ||||||
|  |           parent: false | ||||||
|  |           destination: ${{ env.BUCKET_DIR }} | ||||||
|  | 
 | ||||||
|  |       - name: Upload download endpoint to public bucket | ||||||
|  |         uses: google-github-actions/upload-cloud-storage@v2.2.0 | ||||||
|  |         with: | ||||||
|  |           path: last_download.json | ||||||
|  |           destination: ${{ env.BUCKET_DIR }} | ||||||
|  | 
 | ||||||
|  |       - name: Upload release files to Github | ||||||
|  |         if: ${{ github.event_name == 'release' }} | ||||||
|  |         uses: softprops/action-gh-release@v2 | ||||||
|  |         with: | ||||||
|  |           files: 'out/Zoo*' | ||||||
| 
 | 
 | ||||||
|       - name: Invalidate bucket cache on latest*.yml and last_download.json files |       - name: Invalidate bucket cache on latest*.yml and last_download.json files | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |         run: | | ||||||
|         run: yarn files:invalidate-bucket:nightly |           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 | ||||||
| 
 | 
 | ||||||
|       - name: Tag nightly commit |   announce_release: | ||||||
|         if: ${{ env.IS_NIGHTLY == 'true' }} |     needs: [publish-apps-release] | ||||||
|         uses: actions/github-script@v7 |     runs-on: ubuntu-22.04 | ||||||
|  |     if: github.event_name == 'release' | ||||||
|  |     steps: | ||||||
|  |       - name: Check out code | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  | 
 | ||||||
|  |       - name: Set up Python | ||||||
|  |         uses: actions/setup-python@v5 | ||||||
|         with: |         with: | ||||||
|           script: | |           python-version: '3.x' | ||||||
|             const { VERSION } = process.env           | 
 | ||||||
|             const { owner, repo } = context.repo |       - name: Install dependencies | ||||||
|             const { sha } = context |         run: | | ||||||
|             const ref = `refs/tags/nightly-${VERSION}` |           python -m pip install --upgrade pip | ||||||
|             github.rest.git.createRef({ owner, repo, sha, ref }) |           pip install requests | ||||||
|  | 
 | ||||||
|  |       - name: Announce Release | ||||||
|  |         env: | ||||||
|  |           DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }} | ||||||
|  |           RELEASE_VERSION: ${{ github.event.release.tag_name }} | ||||||
|  |           RELEASE_BODY: ${{ github.event.release.body}} | ||||||
|  |         run: python public/announce_release.py | ||||||
							
								
								
									
										44
									
								
								.github/workflows/cargo-bench.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								.github/workflows/cargo-bench.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,44 @@ | |||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |     paths: | ||||||
|  |       - '**.rs' | ||||||
|  |       - '**/Cargo.toml' | ||||||
|  |       - '**/Cargo.lock' | ||||||
|  |       - '**/rust-toolchain.toml' | ||||||
|  |       - .github/workflows/cargo-bench.yml | ||||||
|  |   pull_request: | ||||||
|  |     paths: | ||||||
|  |       - '**.rs' | ||||||
|  |       - '**/Cargo.toml' | ||||||
|  |       - '**/Cargo.lock' | ||||||
|  |       - '**/rust-toolchain.toml' | ||||||
|  |       - .github/workflows/cargo-bench.yml | ||||||
|  |   workflow_dispatch: | ||||||
|  | permissions: read-all | ||||||
|  | concurrency: | ||||||
|  |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
|  |   cancel-in-progress: true | ||||||
|  | name: cargo bench | ||||||
|  | jobs: | ||||||
|  |   cargo-bench: | ||||||
|  |     name: Benchmark with iai | ||||||
|  |     runs-on: ubuntu-latest-8-cores | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |       - uses: dtolnay/rust-toolchain@stable | ||||||
|  |       - name: Install dependencies | ||||||
|  |         run: | | ||||||
|  |           cargo install cargo-criterion | ||||||
|  |           sudo apt update | ||||||
|  |           sudo apt install -y valgrind | ||||||
|  |       - name: Rust Cache | ||||||
|  |         uses: Swatinem/rust-cache@v2.6.1 | ||||||
|  |       - name: Benchmark kcl library | ||||||
|  |         shell: bash | ||||||
|  |         run: |- | ||||||
|  |           cd src/wasm-lib/kcl; cargo bench --all-features -- iai | ||||||
|  |         env: | ||||||
|  |           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN}} | ||||||
|  |  | ||||||
							
								
								
									
										18
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/cargo-test.yml
									
									
									
									
										vendored
									
									
								
							| @ -2,8 +2,24 @@ on: | |||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - main | ||||||
|  |     paths: | ||||||
|  |       - 'src/wasm-lib/**.rs' | ||||||
|  |       - 'src/wasm-lib/**.hbs' | ||||||
|  |       - '**/Cargo.toml' | ||||||
|  |       - '**/Cargo.lock' | ||||||
|  |       - '**/rust-toolchain.toml' | ||||||
|  |       - 'src/wasm-lib/**.kcl' | ||||||
|  |       - .github/workflows/cargo-test.yml | ||||||
|  |  | ||||||
|   pull_request: |   pull_request: | ||||||
|  |     paths: | ||||||
|  |       - 'src/wasm-lib/**.rs' | ||||||
|  |       - 'src/wasm-lib/**.hbs' | ||||||
|  |       - '**/Cargo.toml' | ||||||
|  |       - '**/Cargo.lock' | ||||||
|  |       - '**/rust-toolchain.toml' | ||||||
|  |       - 'src/wasm-lib/**.kcl' | ||||||
|  |       - .github/workflows/cargo-test.yml | ||||||
|   workflow_dispatch: |   workflow_dispatch: | ||||||
| permissions: read-all | permissions: read-all | ||||||
| concurrency: | concurrency: | ||||||
| @ -51,7 +67,7 @@ jobs: | |||||||
|           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN}} |           KITTYCAD_API_TOKEN: ${{secrets.KITTYCAD_API_TOKEN}} | ||||||
|           RUST_MIN_STACK: 10485760000 |           RUST_MIN_STACK: 10485760000 | ||||||
|       - name: Upload to codecov.io |       - name: Upload to codecov.io | ||||||
|         uses: codecov/codecov-action@v5 |         uses: codecov/codecov-action@v4 | ||||||
|         with: |         with: | ||||||
|           token: ${{secrets.CODECOV_TOKEN}} |           token: ${{secrets.CODECOV_TOKEN}} | ||||||
|           fail_ci_if_error: true |           fail_ci_if_error: true | ||||||
|  | |||||||
							
								
								
									
										32
									
								
								.github/workflows/codemirror-lang-kcl.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										32
									
								
								.github/workflows/codemirror-lang-kcl.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,32 +0,0 @@ | |||||||
| name: CodeMirror Lang KCL |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   pull_request: |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
|  |  | ||||||
| concurrency: |  | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |  | ||||||
|   cancel-in-progress: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   yarn-unit-test: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - uses: actions/setup-node@v4 |  | ||||||
|         with: |  | ||||||
|           node-version-file: '.nvmrc' |  | ||||||
|           cache: 'yarn' |  | ||||||
|  |  | ||||||
|       - run: yarn install |  | ||||||
|         working-directory: packages/codemirror-lang-kcl |  | ||||||
|  |  | ||||||
|       - run: yarn tsc |  | ||||||
|         working-directory: packages/codemirror-lang-kcl |  | ||||||
|  |  | ||||||
|       - name: run unit tests |  | ||||||
|         run: yarn test |  | ||||||
|         working-directory: packages/codemirror-lang-kcl |  | ||||||
							
								
								
									
										37
									
								
								.github/workflows/create-release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								.github/workflows/create-release.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,37 @@ | |||||||
|  | name: Create Release | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   create-release: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       contents: write | ||||||
|  |       pull-requests: read | ||||||
|  |     if: contains(github.event.head_commit.message, 'Cut release v') | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/github-script@v7 | ||||||
|  |         name: Read Cut release PR info and create release | ||||||
|  |         with: | ||||||
|  |           script: | | ||||||
|  |             const { owner, repo } = context.repo | ||||||
|  |             const pulls = await github.rest.repos.listPullRequestsAssociatedWithCommit({ | ||||||
|  |               owner, | ||||||
|  |               repo, | ||||||
|  |               commit_sha: context.sha, | ||||||
|  |             }) | ||||||
|  |             const { title, body } = pulls.data[0] | ||||||
|  |             const version = title.split('Cut release ')[1] | ||||||
|  |  | ||||||
|  |             const result = await github.rest.repos.createRelease({ | ||||||
|  |               owner, | ||||||
|  |               repo, | ||||||
|  |               body, | ||||||
|  |               tag_name: version, | ||||||
|  |               name: version, | ||||||
|  |               draft: true, | ||||||
|  |             }) | ||||||
|  |             console.log(result) | ||||||
							
								
								
									
										187
									
								
								.github/workflows/e2e-flow-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										187
									
								
								.github/workflows/e2e-flow-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,187 +0,0 @@ | |||||||
| name: E2E Flow Tests |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: [ main ] |  | ||||||
|   pull_request: |  | ||||||
|     branches: [ main ] |  | ||||||
|  |  | ||||||
| concurrency: |  | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |  | ||||||
|   cancel-in-progress: true |  | ||||||
|  |  | ||||||
| permissions: |  | ||||||
|   contents: write |  | ||||||
|   pull-requests: write |  | ||||||
|   actions: read |  | ||||||
|  |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|  |  | ||||||
|   check-rust-changes: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     outputs: |  | ||||||
|       rust-changed: ${{ steps.filter.outputs.rust }} |  | ||||||
|  |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - id: filter |  | ||||||
|         name: Check for Rust changes |  | ||||||
|         uses: dorny/paths-filter@v3 |  | ||||||
|         with: |  | ||||||
|           filters: | |  | ||||||
|             rust: |  | ||||||
|               - 'src/wasm-lib/**' |  | ||||||
|  |  | ||||||
|   flow-tests: |  | ||||||
|     timeout-minutes: 60 |  | ||||||
|     name: playwright:electron:${{ matrix.os }} ${{ matrix.shardIndex }} ${{ matrix.shardTotal }} |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         # TODO: enable self-hosted-windows-8-cores once available |  | ||||||
|         os: [namespace-profile-ubuntu-8-cores, namespace-profile-macos-8-cores, windows-16-cores] |  | ||||||
|         shardIndex: [1, 2, 3, 4] |  | ||||||
|         shardTotal: [4] |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     needs: check-rust-changes |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|     - uses: actions/setup-node@v4 |  | ||||||
|       with: |  | ||||||
|         node-version-file: '.nvmrc' |  | ||||||
|         cache: 'yarn' |  | ||||||
|  |  | ||||||
|     - uses: KittyCAD/action-install-cli@main |  | ||||||
|  |  | ||||||
|     - name: Install dependencies |  | ||||||
|       shell: bash |  | ||||||
|       run: yarn |  | ||||||
|  |  | ||||||
|     - name: Cache Playwright Browsers |  | ||||||
|       uses: actions/cache@v4 |  | ||||||
|       with: |  | ||||||
|         path: | |  | ||||||
|           ~/.cache/ms-playwright/ |  | ||||||
|         key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} |  | ||||||
|  |  | ||||||
|     - name: Install Playwright Browsers |  | ||||||
|       shell: bash |  | ||||||
|       run: yarn playwright install --with-deps |  | ||||||
|  |  | ||||||
|     - name: Download Wasm Cache |  | ||||||
|       id: download-wasm |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' |  | ||||||
|       uses: dawidd6/action-download-artifact@v7 |  | ||||||
|       continue-on-error: true |  | ||||||
|       with: |  | ||||||
|         github_token: ${{secrets.GITHUB_TOKEN}} |  | ||||||
|         name: wasm-bundle |  | ||||||
|         workflow: build-and-store-wasm.yml |  | ||||||
|         branch: main |  | ||||||
|         path: src/wasm-lib/pkg |  | ||||||
|  |  | ||||||
|     - name: copy wasm blob |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' |  | ||||||
|       shell: bash |  | ||||||
|       run: cp src/wasm-lib/pkg/wasm_lib_bg.wasm public |  | ||||||
|       continue-on-error: true |  | ||||||
|  |  | ||||||
|     - name: Setup Rust |  | ||||||
|       uses: dtolnay/rust-toolchain@stable |  | ||||||
|  |  | ||||||
|     - name: Cache Wasm (because rust diff) |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' |  | ||||||
|       uses: Swatinem/rust-cache@v2 |  | ||||||
|       with: |  | ||||||
|         workspaces: './src/wasm-lib' |  | ||||||
|  |  | ||||||
|     - name: OR Cache Wasm (because wasm cache failed) |  | ||||||
|       if: steps.download-wasm.outcome == 'failure' |  | ||||||
|       uses: Swatinem/rust-cache@v2 |  | ||||||
|       with: |  | ||||||
|         workspaces: './src/wasm-lib' |  | ||||||
|  |  | ||||||
|     - name: install good sed |  | ||||||
|       if:  ${{ startsWith(matrix.os, 'macos') }} |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         brew install gnu-sed |  | ||||||
|         echo "/opt/homebrew/opt/gnu-sed/libexec/gnubin" >> $GITHUB_PATH |  | ||||||
|  |  | ||||||
|     - name: Install vector |  | ||||||
|       shell: bash |  | ||||||
|       # TODO: figure out what to do with this, it's failing |  | ||||||
|       if: false |  | ||||||
|       run: | |  | ||||||
|         curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh |  | ||||||
|         chmod +x /tmp/vector.sh |  | ||||||
|         /tmp/vector.sh -y -no-modify-path |  | ||||||
|         mkdir -p /tmp/vector |  | ||||||
|         cp .github/workflows/vector.toml /tmp/vector.toml |  | ||||||
|         sed -i "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml |  | ||||||
|         sed -i "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml |  | ||||||
|         sed -i "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml |  | ||||||
|         sed -i "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml |  | ||||||
|         sed -i "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml |  | ||||||
|         cat /tmp/vector.toml |  | ||||||
|         ${HOME}/.vector/bin/vector --config /tmp/vector.toml & |  | ||||||
|  |  | ||||||
|     - name: Build Wasm (because rust diff) |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' |  | ||||||
|       shell: bash |  | ||||||
|       run: yarn build:wasm |  | ||||||
|  |  | ||||||
|     - name: OR Build Wasm (because wasm cache failed) |  | ||||||
|       if: steps.download-wasm.outcome == 'failure' |  | ||||||
|       shell: bash |  | ||||||
|       run: yarn build:wasm |  | ||||||
|  |  | ||||||
|     - name: build web |  | ||||||
|       shell: bash |  | ||||||
|       run: yarn tronb:vite:dev |  | ||||||
|  |  | ||||||
|     - name: Clean up test-results |  | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |  | ||||||
|       continue-on-error: true |  | ||||||
|       run: rm -r test-results |  | ||||||
|  |  | ||||||
|     - uses: actions/download-artifact@v4 |  | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |  | ||||||
|       continue-on-error: true |  | ||||||
|       with: |  | ||||||
|         name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |  | ||||||
|         path: test-results/ |  | ||||||
|  |  | ||||||
|     - name: Run playwright/electron flow (with retries) |  | ||||||
|       id: retry |  | ||||||
|       if: ${{ !cancelled() && (success() || failure()) }} |  | ||||||
|       shell: bash |  | ||||||
|       run: | |  | ||||||
|         .github/ci-cd-scripts/playwright-electron.sh ${{matrix.shardIndex}} ${{matrix.shardTotal}} ${{matrix.os}} |  | ||||||
|       env: |  | ||||||
|         CI: true |  | ||||||
|         FAIL_ON_CONSOLE_ERRORS: true |  | ||||||
|         NODE_ENV: development |  | ||||||
|         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |  | ||||||
|         VITE_KC_SKIP_AUTH: true |  | ||||||
|         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |  | ||||||
|  |  | ||||||
|     - uses: actions/upload-artifact@v4 |  | ||||||
|       if: always() |  | ||||||
|       with: |  | ||||||
|         name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |  | ||||||
|         path: test-results/ |  | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |  | ||||||
|         overwrite: true |  | ||||||
|  |  | ||||||
|     - uses: actions/upload-artifact@v4 |  | ||||||
|       if: always() |  | ||||||
|       with: |  | ||||||
|         name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} |  | ||||||
|         path: playwright-report/ |  | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |  | ||||||
|         overwrite: true |  | ||||||
							
								
								
									
										145
									
								
								.github/workflows/e2e-snapshot-tests.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										145
									
								
								.github/workflows/e2e-snapshot-tests.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,145 +0,0 @@ | |||||||
| name: E2E Snapshot Tests |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: [ main ] |  | ||||||
|   pull_request: |  | ||||||
|     branches: [ main ] |  | ||||||
|  |  | ||||||
| concurrency: |  | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |  | ||||||
|   cancel-in-progress: true |  | ||||||
|  |  | ||||||
| permissions: |  | ||||||
|   contents: write |  | ||||||
|   pull-requests: write |  | ||||||
|   actions: read |  | ||||||
|  |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|  |  | ||||||
|   check-rust-changes: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     outputs: |  | ||||||
|       rust-changed: ${{ steps.filter.outputs.rust }} |  | ||||||
|  |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - id: filter |  | ||||||
|         name: Check for Rust changes |  | ||||||
|         uses: dorny/paths-filter@v3 |  | ||||||
|         with: |  | ||||||
|           filters: | |  | ||||||
|             rust: |  | ||||||
|               - 'src/wasm-lib/**' |  | ||||||
|  |  | ||||||
|   snapshot-tests: |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     needs: check-rust-changes |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|     - uses: actions/setup-node@v4 |  | ||||||
|       with: |  | ||||||
|         node-version-file: '.nvmrc' |  | ||||||
|         cache: 'yarn' |  | ||||||
|  |  | ||||||
|     - name: Install dependencies |  | ||||||
|       run: yarn |  | ||||||
|  |  | ||||||
|     - name: Cache Playwright Browsers |  | ||||||
|       uses: actions/cache@v4 |  | ||||||
|       with: |  | ||||||
|         path: | |  | ||||||
|           ~/.cache/ms-playwright/ |  | ||||||
|         key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} |  | ||||||
|  |  | ||||||
|     - name: Install Playwright Browsers |  | ||||||
|       run: yarn playwright install --with-deps |  | ||||||
|  |  | ||||||
|     - name: Download Wasm Cache |  | ||||||
|       id: download-wasm |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' |  | ||||||
|       uses: dawidd6/action-download-artifact@v7 |  | ||||||
|       continue-on-error: true |  | ||||||
|       with: |  | ||||||
|         github_token: ${{secrets.GITHUB_TOKEN}} |  | ||||||
|         name: wasm-bundle |  | ||||||
|         workflow: build-and-store-wasm.yml |  | ||||||
|         branch: main |  | ||||||
|         path: src/wasm-lib/pkg |  | ||||||
|  |  | ||||||
|     - name: copy wasm blob |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'false' |  | ||||||
|       run: cp src/wasm-lib/pkg/wasm_lib_bg.wasm public |  | ||||||
|       continue-on-error: true |  | ||||||
|  |  | ||||||
|     - name: Setup Rust |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' |  | ||||||
|       uses: dtolnay/rust-toolchain@stable |  | ||||||
|  |  | ||||||
|     - name: Cache Wasm (because rust diff) |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' |  | ||||||
|       uses: Swatinem/rust-cache@v2 |  | ||||||
|       with: |  | ||||||
|         workspaces: './src/wasm-lib' |  | ||||||
|  |  | ||||||
|     - name: OR Cache Wasm (because wasm cache failed) |  | ||||||
|       if: steps.download-wasm.outcome == 'failure' |  | ||||||
|       uses: Swatinem/rust-cache@v2 |  | ||||||
|       with: |  | ||||||
|         workspaces: './src/wasm-lib' |  | ||||||
|  |  | ||||||
|     - name: Build Wasm (because rust diff) |  | ||||||
|       if: needs.check-rust-changes.outputs.rust-changed == 'true' |  | ||||||
|       run: yarn build:wasm |  | ||||||
|  |  | ||||||
|     - name: OR Build Wasm (because wasm cache failed) |  | ||||||
|       if: steps.download-wasm.outcome == 'failure' |  | ||||||
|       run: yarn build:wasm |  | ||||||
|  |  | ||||||
|     - name: build web |  | ||||||
|       run: yarn tronb:vite:dev |  | ||||||
|  |  | ||||||
|     - name: Run chrome snapshots |  | ||||||
|       run: | |  | ||||||
|         PLATFORM=web yarn playwright test --config=playwright.config.ts --retries="3" --update-snapshots --grep=@snapshot |  | ||||||
|       env: |  | ||||||
|         CI: true |  | ||||||
|         NODE_ENV: development |  | ||||||
|         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |  | ||||||
|         VITE_KC_SKIP_AUTH: true |  | ||||||
|         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |  | ||||||
|         snapshottoken: ${{ secrets.KITTYCAD_API_TOKEN }} |  | ||||||
|  |  | ||||||
|     - name: check for changes |  | ||||||
|       id: git-check |  | ||||||
|       run: | |  | ||||||
|         { |  | ||||||
|           echo 'changes<<EOF' |  | ||||||
|           git diff --name-only e2e/playwright/snapshot-tests.spec.ts-snapshots |  | ||||||
|           echo EOF |  | ||||||
|         } >> "$GITHUB_OUTPUT" |  | ||||||
|  |  | ||||||
|     # only upload artifacts if there's actually changes |  | ||||||
|     - name: Upload changes, if any |  | ||||||
|       if: steps.git-check.outputs.changes != '' |  | ||||||
|       uses: actions/upload-artifact@v4 |  | ||||||
|       with: |  | ||||||
|         name: playwright-snapshots-${{ runner.os }}-${{ github.sha }} |  | ||||||
|         path: ${{ steps.git-check.outputs.changes }} |  | ||||||
|  |  | ||||||
|     - name: Upload report, if any |  | ||||||
|       uses: actions/upload-artifact@v4 |  | ||||||
|       if: steps.git-check.outputs.changes != '' |  | ||||||
|       with: |  | ||||||
|         name: playwright-report-${{ runner.os }}-${{ github.sha }} |  | ||||||
|         path: playwright-report/ |  | ||||||
|         include-hidden-files: true |  | ||||||
|         retention-days: 30 |  | ||||||
|  |  | ||||||
|     - name: Fail the run if we have snapshot updates |  | ||||||
|       if: steps.git-check.outputs.changes != '' |  | ||||||
|       run: exit 1 |  | ||||||
|  |  | ||||||
|     # TODO: check if we could comment on the PR as well |  | ||||||
							
								
								
									
										356
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										356
									
								
								.github/workflows/e2e-tests.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,356 @@ | |||||||
|  | name: E2E Tests | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: [ main ] | ||||||
|  |   pull_request: | ||||||
|  |     branches: [ main ] | ||||||
|  |  | ||||||
|  | concurrency: | ||||||
|  |   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | ||||||
|  |   cancel-in-progress: true | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: write | ||||||
|  |   pull-requests: write | ||||||
|  |   actions: read | ||||||
|  |  | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |  | ||||||
|  |   check-rust-changes: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     outputs: | ||||||
|  |       rust-changed: ${{ steps.filter.outputs.rust }} | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - id: filter | ||||||
|  |         name: Check for Rust changes | ||||||
|  |         uses: dorny/paths-filter@v3 | ||||||
|  |         with: | ||||||
|  |           filters: | | ||||||
|  |             rust: | ||||||
|  |               - 'src/wasm-lib/**' | ||||||
|  |  | ||||||
|  |   browser: | ||||||
|  |     timeout-minutes: ${{ matrix.os == 'macos-14' && 60 || 50 }} | ||||||
|  |     name: playwright:browser:${{ matrix.os }} ${{ matrix.shardIndex }} ${{ matrix.shardTotal }} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest-8-cores, windows-latest-8-cores] | ||||||
|  |         shardIndex: [1, 2, 3, 4] | ||||||
|  |         shardTotal: [4] | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     needs: check-rust-changes | ||||||
|  |     steps: | ||||||
|  |     - name: Tune GitHub-hosted runner network | ||||||
|  |       uses: smorimoto/tune-github-hosted-runner-network@v1 | ||||||
|  |     - uses: actions/checkout@v4 | ||||||
|  |     - uses: actions/setup-node@v4 | ||||||
|  |       with: | ||||||
|  |         node-version-file: '.nvmrc' | ||||||
|  |         cache: 'yarn' | ||||||
|  |     - uses: KittyCAD/action-install-cli@main | ||||||
|  |     - name: Install dependencies | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn | ||||||
|  |     - name: Cache Playwright Browsers | ||||||
|  |       uses: actions/cache@v4 | ||||||
|  |       with: | ||||||
|  |         path: | | ||||||
|  |           ~/.cache/ms-playwright/ | ||||||
|  |         key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} | ||||||
|  |     - name: Install Playwright Browsers | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn playwright install --with-deps | ||||||
|  |     - name: Download Wasm Cache | ||||||
|  |       id: download-wasm | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||||
|  |       uses: dawidd6/action-download-artifact@v6 | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         github_token: ${{secrets.GITHUB_TOKEN}} | ||||||
|  |         name: wasm-bundle | ||||||
|  |         workflow: build-and-store-wasm.yml | ||||||
|  |         branch: main | ||||||
|  |         path: src/wasm-lib/pkg | ||||||
|  |     - name: copy wasm blob | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||||
|  |       shell: bash | ||||||
|  |       run: cp src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||||
|  |       continue-on-error: true | ||||||
|  |     - name: Setup Rust | ||||||
|  |       uses: dtolnay/rust-toolchain@stable | ||||||
|  |     - name: Cache Wasm (because rust diff) | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'true' | ||||||
|  |       uses: Swatinem/rust-cache@v2 | ||||||
|  |       with: | ||||||
|  |         workspaces: './src/wasm-lib' | ||||||
|  |     - name: OR Cache Wasm (because wasm cache failed) | ||||||
|  |       if: steps.download-wasm.outcome == 'failure' | ||||||
|  |       uses: Swatinem/rust-cache@v2 | ||||||
|  |       with: | ||||||
|  |         workspaces: './src/wasm-lib' | ||||||
|  |     - name: install good sed | ||||||
|  |       if:  ${{ startsWith(matrix.os, 'macos') }} | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         brew install gnu-sed | ||||||
|  |         echo "/opt/homebrew/opt/gnu-sed/libexec/gnubin" >> $GITHUB_PATH | ||||||
|  |     - name: Install vector | ||||||
|  |       shell: bash | ||||||
|  |       if:  ${{ !startsWith(matrix.os, 'windows') }} | ||||||
|  |       run: | | ||||||
|  |         curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh | ||||||
|  |         chmod +x /tmp/vector.sh | ||||||
|  |         /tmp/vector.sh -y -no-modify-path | ||||||
|  |         mkdir -p /tmp/vector | ||||||
|  |         cp .github/workflows/vector.toml /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml | ||||||
|  |         cat /tmp/vector.toml | ||||||
|  |         ${HOME}/.vector/bin/vector --config /tmp/vector.toml & | ||||||
|  |     - name: Build Wasm (because rust diff) | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'true' | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn build:wasm | ||||||
|  |     - name: OR Build Wasm (because wasm cache failed) | ||||||
|  |       if: steps.download-wasm.outcome == 'failure' | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn build:wasm | ||||||
|  |     - name: build web | ||||||
|  |       run: yarn build:local | ||||||
|  |       shell: bash | ||||||
|  |     - name: Run ubuntu/chrome snapshots | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         yarn playwright test --project="Google Chrome" --config=playwright.ci.config.ts --retries="3" --update-snapshots --grep=@snapshot  --shard=${{ matrix.shardIndex }}/${{ matrix.shardTotal }} | ||||||
|  |       env: | ||||||
|  |         CI: true | ||||||
|  |         NODE_ENV: development | ||||||
|  |         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|  |         VITE_KC_SKIP_AUTH: true | ||||||
|  |         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|  |         snapshottoken: ${{ secrets.KITTYCAD_API_TOKEN }} | ||||||
|  |     - uses: actions/upload-artifact@v4 | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       with: | ||||||
|  |         name: playwright-report-${{ matrix.os }}-snapshot-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|  |         path: playwright-report/ | ||||||
|  |         include-hidden-files: true | ||||||
|  |         retention-days: 30 | ||||||
|  |         overwrite: true | ||||||
|  |     - name: Clean up test-results | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       continue-on-error: true | ||||||
|  |       run: rm -r test-results | ||||||
|  |     - name: check for changes | ||||||
|  |       shell: bash | ||||||
|  |       id: git-check | ||||||
|  |       run: | | ||||||
|  |           git add . | ||||||
|  |           if git status | grep -q "Changes to be committed" | ||||||
|  |           then echo "modified=true" >> $GITHUB_OUTPUT | ||||||
|  |           else echo "modified=false" >> $GITHUB_OUTPUT | ||||||
|  |           fi | ||||||
|  |     - name: Commit changes, if any | ||||||
|  |       if: steps.git-check.outputs.modified == 'true' | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         git add . | ||||||
|  |         git config --local user.email "github-actions[bot]@users.noreply.github.com" | ||||||
|  |         git config --local user.name "github-actions[bot]" | ||||||
|  |         git remote set-url origin https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }}.git | ||||||
|  |         git fetch origin | ||||||
|  |         echo ${{ github.head_ref }} | ||||||
|  |         git checkout ${{ github.head_ref }} | ||||||
|  |         git commit -am "A snapshot a day keeps the bugs away! 📷🐛 (OS: ${{matrix.os}})" || true | ||||||
|  |         git push | ||||||
|  |         git push origin ${{ github.head_ref }} | ||||||
|  |     # only upload artifacts if there's actually changes | ||||||
|  |     - uses: actions/upload-artifact@v4 | ||||||
|  |       if: steps.git-check.outputs.modified == 'true' | ||||||
|  |       with: | ||||||
|  |         name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|  |         path: playwright-report/ | ||||||
|  |         include-hidden-files: true | ||||||
|  |         retention-days: 30 | ||||||
|  |     - uses: actions/download-artifact@v4 | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|  |         path: test-results/ | ||||||
|  |     - name: Run playwright/chrome flow (with retries) | ||||||
|  |       id: retry | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         .github/ci-cd-scripts/playwright-browser-chrome.sh ${{matrix.shardIndex}} ${{matrix.shardTotal}} ${{matrix.os}} | ||||||
|  |       env: | ||||||
|  |         CI: true | ||||||
|  |         FAIL_ON_CONSOLE_ERRORS: true | ||||||
|  |         NODE_ENV: development | ||||||
|  |         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|  |         VITE_KC_SKIP_AUTH: true | ||||||
|  |         token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|  |     - name: send to axiom | ||||||
|  |       if: always() | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         node playwrightProcess.mjs | tee /tmp/github-actions.log | ||||||
|  |     - uses: actions/upload-artifact@v4 | ||||||
|  |       if: always() | ||||||
|  |       with: | ||||||
|  |         name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|  |         path: test-results/ | ||||||
|  |         include-hidden-files: true | ||||||
|  |         retention-days: 30 | ||||||
|  |         overwrite: true | ||||||
|  |     - uses: actions/upload-artifact@v4 | ||||||
|  |       if: always() | ||||||
|  |       with: | ||||||
|  |         name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | ||||||
|  |         path: playwright-report/ | ||||||
|  |         include-hidden-files: true | ||||||
|  |         retention-days: 30 | ||||||
|  |         overwrite: true | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   electron: | ||||||
|  |     name: playwright:electron:${{matrix.os}} | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         os: [ubuntu-latest-8-cores, windows-latest-8-cores, macos-14-large] | ||||||
|  |     timeout-minutes: 60 | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     needs: check-rust-changes | ||||||
|  |     steps: | ||||||
|  |     - name: Tune GitHub-hosted runner network | ||||||
|  |       uses: smorimoto/tune-github-hosted-runner-network@v1 | ||||||
|  |     - uses: actions/checkout@v4 | ||||||
|  |     - uses: actions/setup-node@v4 | ||||||
|  |       with: | ||||||
|  |         node-version-file: '.nvmrc' | ||||||
|  |         cache: 'yarn' | ||||||
|  |     - uses: KittyCAD/action-install-cli@main | ||||||
|  |     - name: Install dependencies | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn | ||||||
|  |     - name: Cache Playwright Browsers | ||||||
|  |       uses: actions/cache@v4 | ||||||
|  |       with: | ||||||
|  |         path: | | ||||||
|  |           ~/.cache/ms-playwright/ | ||||||
|  |         key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} | ||||||
|  |     - name: Install Playwright Browsers | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn playwright install chromium --with-deps | ||||||
|  |     - name: Download Wasm Cache | ||||||
|  |       id: download-wasm | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||||
|  |       uses: dawidd6/action-download-artifact@v6 | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         github_token: ${{secrets.GITHUB_TOKEN}} | ||||||
|  |         name: wasm-bundle | ||||||
|  |         workflow: build-and-store-wasm.yml | ||||||
|  |         branch: main | ||||||
|  |         path: src/wasm-lib/pkg | ||||||
|  |     - name: copy wasm blob | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'false' | ||||||
|  |       shell: bash | ||||||
|  |       run: cp src/wasm-lib/pkg/wasm_lib_bg.wasm public | ||||||
|  |       continue-on-error: true | ||||||
|  |     - name: Setup Rust | ||||||
|  |       uses: dtolnay/rust-toolchain@stable | ||||||
|  |     - name: Cache Wasm (because rust diff) | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'true' | ||||||
|  |       uses: Swatinem/rust-cache@v2 | ||||||
|  |       with: | ||||||
|  |         workspaces: './src/wasm-lib' | ||||||
|  |     - name: OR Cache Wasm (because wasm cache failed) | ||||||
|  |       if: steps.download-wasm.outcome == 'failure' | ||||||
|  |       uses: Swatinem/rust-cache@v2 | ||||||
|  |       with: | ||||||
|  |         workspaces: './src/wasm-lib' | ||||||
|  |     - name: install good sed | ||||||
|  |       if:  ${{ startsWith(matrix.os, 'macos') }} | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         brew install gnu-sed | ||||||
|  |         echo "/opt/homebrew/opt/gnu-sed/libexec/gnubin" >> $GITHUB_PATH | ||||||
|  |     - name: Install vector | ||||||
|  |       if:  ${{ startsWith(matrix.os, 'ubuntu') }} | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh | ||||||
|  |         chmod +x /tmp/vector.sh | ||||||
|  |         /tmp/vector.sh -y -no-modify-path | ||||||
|  |         mkdir -p /tmp/vector | ||||||
|  |         cp .github/workflows/vector.toml /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml | ||||||
|  |         sed -i "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml | ||||||
|  |         cat /tmp/vector.toml | ||||||
|  |         ${HOME}/.vector/bin/vector --config /tmp/vector.toml & | ||||||
|  |     - name: Build Wasm (because rust diff) | ||||||
|  |       if: needs.check-rust-changes.outputs.rust-changed == 'true' | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn build:wasm | ||||||
|  |     - name: OR Build Wasm (because wasm cache failed) | ||||||
|  |       if: steps.download-wasm.outcome == 'failure' | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn build:wasm | ||||||
|  |     - name: build electron | ||||||
|  |       shell: bash | ||||||
|  |       run: yarn tron:package | ||||||
|  |     - uses: actions/download-artifact@v4 | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       continue-on-error: true | ||||||
|  |       with: | ||||||
|  |         name: test-results-electron-${{ matrix.os }}-${{ github.sha }} | ||||||
|  |         path: test-results/ | ||||||
|  |     - name: Run electron tests (with retries) | ||||||
|  |       id: retry | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         .github/ci-cd-scripts/playwright-electron.sh ${{ matrix.os }} | ||||||
|  |       env: | ||||||
|  |         CI: true | ||||||
|  |         FAIL_ON_CONSOLE_ERRORS: true | ||||||
|  |         NODE_ENV: development | ||||||
|  |         VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | ||||||
|  |         VITE_KC_SKIP_AUTH: true | ||||||
|  |         IS_UBUNTU: ${{ startsWith(matrix.os, 'ubuntu') && 'true' || 'false' }} | ||||||
|  |         #DEBUG: 'pw:browser*' | ||||||
|  |     - name: send to axiom | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) && !startsWith(matrix.os, 'windows') }} | ||||||
|  |       shell: bash | ||||||
|  |       run: | | ||||||
|  |         node playwrightProcess.mjs | tee /tmp/github-actions.log | ||||||
|  |     - uses: actions/upload-artifact@v4 | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       with: | ||||||
|  |         name: test-results-electron-${{ matrix.os }}-${{ github.sha }} | ||||||
|  |         path: test-results/ | ||||||
|  |         include-hidden-files: true | ||||||
|  |         retention-days: 30 | ||||||
|  |         overwrite: true | ||||||
|  |     - uses: actions/upload-artifact@v4 | ||||||
|  |       if: ${{ !cancelled() && (success() || failure()) }} | ||||||
|  |       with: | ||||||
|  |         name: playwright-report-electron-${{ matrix.os }}-${{ github.sha }} | ||||||
|  |         path: playwright-report/ | ||||||
|  |         include-hidden-files: true | ||||||
|  |         retention-days: 30 | ||||||
|  |         overwrite: true | ||||||
							
								
								
									
										160
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										160
									
								
								.github/workflows/publish-apps-release.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,160 +0,0 @@ | |||||||
| name: publish-apps-release |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   release: |  | ||||||
|     types: [published] |  | ||||||
|  |  | ||||||
| concurrency: |  | ||||||
|   group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} |  | ||||||
|   cancel-in-progress: true |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   publish-apps-release: |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     permissions: |  | ||||||
|       contents: write |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - uses: actions/setup-node@v4 |  | ||||||
|         with: |  | ||||||
|           node-version-file: '.nvmrc' |  | ||||||
|           cache: 'yarn' |  | ||||||
|  |  | ||||||
|       - name: Find tag workflow id |  | ||||||
|         id: tag_workflow_id |  | ||||||
|         env: |  | ||||||
|           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|         run: | |  | ||||||
|           id=$(gh run ls --repo kittycad/modeling-app -w build-apps.yml --branch ${{ github.event.release.tag_name }} --json databaseId | jq '.[0].databaseId') |  | ||||||
|           echo "id=$id" >> "$GITHUB_OUTPUT" |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-arm64-win |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|            |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-x64-win |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-yml-win |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-arm64-mac |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-x64-mac |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-yml-mac |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-arm64-linux |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-x64-linux |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-yml-linux |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - uses: actions/download-artifact@v4 |  | ||||||
|         with: |  | ||||||
|           name: out-download-json |  | ||||||
|           path: out |  | ||||||
|           run-id: ${{ steps.tag_workflow_id.outputs.id }} |  | ||||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
|  |  | ||||||
|       - name: List artifacts |  | ||||||
|         run: ls -R out |  | ||||||
|  |  | ||||||
|       - name: Override release notes |  | ||||||
|         env: |  | ||||||
|           NOTES: ${{ github.event.release.body }} |  | ||||||
|         run: yarn files:set-notes |  | ||||||
|  |  | ||||||
|       - name: Authenticate to Google Cloud |  | ||||||
|         uses: 'google-github-actions/auth@v2.1.8' |  | ||||||
|         with: |  | ||||||
|           credentials_json: '${{ secrets.GOOGLE_CLOUD_DL_SA }}' |  | ||||||
|  |  | ||||||
|       - name: Set up Google Cloud SDK |  | ||||||
|         uses: google-github-actions/setup-gcloud@v2.1.4 |  | ||||||
|         with: |  | ||||||
|           project_id: ${{ env.GOOGLE_CLOUD_PROJECT_ID }} |  | ||||||
|  |  | ||||||
|       - name: Upload release files to public bucket |  | ||||||
|         uses: google-github-actions/upload-cloud-storage@v2.2.2 |  | ||||||
|         with: |  | ||||||
|           path: out |  | ||||||
|           glob: '*' |  | ||||||
|           parent: false |  | ||||||
|           destination: 'dl.kittycad.io/releases/modeling-app' |  | ||||||
|  |  | ||||||
|       - name: Invalidate bucket cache on latest*.yml and last_download.json files |  | ||||||
|         run: yarn files:invalidate-bucket |  | ||||||
|  |  | ||||||
|       - name: Upload release files to Github |  | ||||||
|         if: ${{ github.event_name == 'release' }} |  | ||||||
|         uses: softprops/action-gh-release@v2 |  | ||||||
|         with: |  | ||||||
|           files: 'out/Zoo*' |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   announce_release: |  | ||||||
|     needs: [publish-apps-release] |  | ||||||
|     runs-on: ubuntu-22.04 |  | ||||||
|     steps: |  | ||||||
|       - name: Check out code |  | ||||||
|         uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - name: Set up Python |  | ||||||
|         uses: actions/setup-python@v5 |  | ||||||
|         with: |  | ||||||
|           python-version: '3.x' |  | ||||||
|  |  | ||||||
|       - name: Install dependencies |  | ||||||
|         run: | |  | ||||||
|           python -m pip install --upgrade pip |  | ||||||
|           pip install requests |  | ||||||
|  |  | ||||||
|       - name: Announce Release |  | ||||||
|         env: |  | ||||||
|           DISCORD_WEBHOOK_URL: ${{ secrets.DISCORD_WEBHOOK_URL }} |  | ||||||
|           RELEASE_VERSION: ${{ github.event.release.tag_name }} |  | ||||||
|           RELEASE_BODY: ${{ github.event.release.body }} |  | ||||||
|         run: python public/announce_release.py |  | ||||||
							
								
								
									
										25
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								.github/workflows/static-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -81,31 +81,6 @@ jobs: | |||||||
|       - name: Run codespell |       - name: Run codespell | ||||||
|         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-kcl-samples: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|  |  | ||||||
|       - uses: actions/setup-node@v4 |  | ||||||
|         with: |  | ||||||
|           node-version-file: '.nvmrc' |  | ||||||
|           cache: 'yarn' |  | ||||||
|  |  | ||||||
|       - run: yarn install |  | ||||||
|       - run: yarn build:wasm |  | ||||||
|  |  | ||||||
|       - run: yarn simpleserver:bg |  | ||||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} |  | ||||||
|  |  | ||||||
|       - name: Install Chromium Browser |  | ||||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} |  | ||||||
|         run: yarn playwright install chromium --with-deps |  | ||||||
|  |  | ||||||
|       - name: run unit tests for kcl samples |  | ||||||
|         if: ${{ github.event_name != 'release' && github.event_name != 'schedule' }} |  | ||||||
|         run: yarn test:unit:kcl-samples |  | ||||||
|         env: |  | ||||||
|           VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} |  | ||||||
|  |  | ||||||
|   yarn-unit-test: |   yarn-unit-test: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -25,7 +25,6 @@ yarn-error.log* | |||||||
|  |  | ||||||
| .idea | .idea | ||||||
| .vscode | .vscode | ||||||
| .helix |  | ||||||
| src/wasm-lib/.idea | src/wasm-lib/.idea | ||||||
| src/wasm-lib/.vscode | src/wasm-lib/.vscode | ||||||
|  |  | ||||||
| @ -45,7 +44,7 @@ e2e/playwright/temp3.png | |||||||
| e2e/playwright/export-snapshots/* | e2e/playwright/export-snapshots/* | ||||||
| !e2e/playwright/export-snapshots/*.png | !e2e/playwright/export-snapshots/*.png | ||||||
|  |  | ||||||
| /kcl-samples |  | ||||||
| /test-results/ | /test-results/ | ||||||
| /playwright-report/ | /playwright-report/ | ||||||
| /blob-report/ | /blob-report/ | ||||||
| @ -62,7 +61,6 @@ Mac_App_Distribution.provisionprofile | |||||||
| *.tsbuildinfo | *.tsbuildinfo | ||||||
| src/wasm-lib/pkg | src/wasm-lib/pkg | ||||||
|  |  | ||||||
| .eslintcache |  | ||||||
| venv | venv | ||||||
| .vite/ | .vite/ | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,2 +0,0 @@ | |||||||
| [editor] |  | ||||||
| auto-format = true |  | ||||||
| @ -1,10 +0,0 @@ | |||||||
| [language-server.eslint] |  | ||||||
| args = ["--stdio"] |  | ||||||
| command = "vscode-eslint-language-server" |  | ||||||
|  |  | ||||||
| [[language]] |  | ||||||
| name = "typescript" |  | ||||||
| auto-format = true |  | ||||||
| formatter = { command = "node_modules/.bin/prettier", args = ["--parser", "typescript"] } |  | ||||||
| language-servers = [ { name = "eslint", only-features = [ "diagnostics" ] }, "typescript-language-server" ] |  | ||||||
|  |  | ||||||
							
								
								
									
										43
									
								
								INSTALL.md
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								INSTALL.md
									
									
									
									
									
								
							| @ -1,43 +0,0 @@ | |||||||
| # Setting Up Zoo Modeling App |  | ||||||
|  |  | ||||||
| Compared to other CAD software, getting Zoo Modeling App up and running is quick and straightforward across platforms. It's about 100MB to download and is quick to install. |  | ||||||
|  |  | ||||||
| ## Windows |  | ||||||
|  |  | ||||||
| 1. Download the [Zoo Modeling App installer](https://zoo.dev/modeling-app/download) for Windows and for your processor type. |  | ||||||
|  |  | ||||||
| 2. Once downloaded, run the installer `Zoo Modeling App-{version}-{arch}-win.exe` which should take a few seconds. |  | ||||||
|  |  | ||||||
| 3. The installation happens at `C:\Program Files\Zoo Modeling App`. A shortcut in the start menu is also created so you can run the app easily by clicking on it. |  | ||||||
|  |  | ||||||
| ## macOS |  | ||||||
|  |  | ||||||
| 1. Download the [Zoo Modeling App installer](https://zoo.dev/modeling-app/download) for macOS and for your processor type. |  | ||||||
|  |  | ||||||
| 2. Once downloaded, open the disk image `Zoo Modeling App-{version}-{arch}-mac.dmg` and drag the applications to your `Applications` directory. |  | ||||||
|  |  | ||||||
| 3. You can then open your `Applications` directory and double-click on `Zoo Modeling App` to open. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Linux  |  | ||||||
|  |  | ||||||
| 1. Download the [Zoo Modeling App installer](https://zoo.dev/modeling-app/download) for Linux and for your processor type. |  | ||||||
|  |  | ||||||
| 2. Install the dependencies needed to run the [AppImage format](https://appimage.org/). |  | ||||||
|     -  On Ubuntu, install the FUSE library with these commands in a terminal. |  | ||||||
|        ```bash |  | ||||||
|        sudo apt update |  | ||||||
|        sudo apt install libfuse2 |  | ||||||
|        ``` |  | ||||||
|     - Optionally, follow [these steps](https://github.com/probonopd/go-appimage/blob/master/src/appimaged/README.md#initial-setup) to install `appimaged`. It is a daemon that makes interacting with AppImage files more seamless.  |  | ||||||
|     - Once installed, copy the downloaded `Zoo Modeling App-{version}-{arch}-linux.AppImage` to the directory of your choice, for instance `~/Applications`. |  | ||||||
|  |  | ||||||
|    - `appimaged` should automatically find it and make it executable. If not, run: |  | ||||||
|      ```bash |  | ||||||
|      chmod a+x ~/Applications/Zoo\ Modeling\ App-{version}-{arch}-linux.AppImage |  | ||||||
|      ``` |  | ||||||
|  |  | ||||||
| 3. You can double-click on the AppImage to run it, or in a terminal with this command: |  | ||||||
|    ```bash |  | ||||||
|     ~/Applications/Zoo\ Modeling\ App-{version}-{arch}-linux.AppImage |  | ||||||
|    ``` |  | ||||||
							
								
								
									
										2
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
									
									
									
									
								
							| @ -19,7 +19,7 @@ $(XSTATE_TYPEGENS): $(TS_SRC) | |||||||
| 	yarn xstate typegen 'src/**/*.ts?(x)' | 	yarn xstate typegen 'src/**/*.ts?(x)' | ||||||
|  |  | ||||||
| public/wasm_lib_bg.wasm: $(WASM_LIB_FILES) | public/wasm_lib_bg.wasm: $(WASM_LIB_FILES) | ||||||
| 	yarn build:wasm | 	yarn build:wasm-dev | ||||||
|  |  | ||||||
| node_modules: package.json yarn.lock | node_modules: package.json yarn.lock | ||||||
| 	yarn install | 	yarn install | ||||||
|  | |||||||
							
								
								
									
										122
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										122
									
								
								README.md
									
									
									
									
									
								
							| @ -99,9 +99,9 @@ yarn tron:start | |||||||
|  |  | ||||||
| This will start the application and hot-reload on changes. | This will start the application and hot-reload on changes. | ||||||
|  |  | ||||||
| Devtools can be opened with the usual Cmd-Opt-I (Mac) or Ctrl-Shift-I (Linux and Windows). | Devtools can be opened with the usual Cmd/Ctrl-Shift-I. | ||||||
|  |  | ||||||
| To build with electron-builder, run `yarn tronb:package:dev` (or `yarn tronb:package:prod` to point to the .env.production variables) | To build, run `yarn tron:package`. | ||||||
|  |  | ||||||
| ## Checking out commits / Bisecting | ## Checking out commits / Bisecting | ||||||
|  |  | ||||||
| @ -110,7 +110,7 @@ Which commands from setup are one off vs need to be run every time? | |||||||
| The following will need to be run when checking out a new commit and guarantees the build is not stale: | The following will need to be run when checking out a new commit and guarantees the build is not stale: | ||||||
| ```bash | ```bash | ||||||
| yarn install | yarn install | ||||||
| yarn build:wasm | yarn build:wasm-dev # or yarn build:wasm for slower but more production-like build | ||||||
| yarn start # or yarn build:local && yarn serve for slower but more production-like build | yarn start # or yarn build:local && yarn serve for slower but more production-like build | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @ -128,37 +128,45 @@ Before you submit a contribution PR to this repo, please ensure that: | |||||||
|  |  | ||||||
| ## Release a new version | ## Release a new version | ||||||
|  |  | ||||||
| #### 1. Create a 'Cut release $VERSION' issue | #### 1. Bump the versions by running `./make-release.sh` | ||||||
|  |  | ||||||
| It will be used to document changelog discussions and release testing. | 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. | ||||||
|  |  | ||||||
| https://github.com/KittyCAD/modeling-app/issues/new |  | ||||||
|  |  | ||||||
| #### 2. Push a new tag |  | ||||||
|  |  | ||||||
| Create a new tag and push it to the repo. The `semantic-release.sh` script will automatically bump the minor part, which we use the most. For instance going from `v0.27.0` to `v0.28.0`. |  | ||||||
|  |  | ||||||
| ``` | ``` | ||||||
| VERSION=$(./scripts/semantic-release.sh) | git branch -D main | ||||||
| git tag $VERSION | git checkout main | ||||||
| git push origin --tags | 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> | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| This will trigger the `build-apps` workflow, set the version, build & sign the apps, and generate release files as well as updater-test artifacts. | 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 minor` for minor; or | ||||||
|  | - run `./make-release.sh major` for major. | ||||||
|  |  | ||||||
| The workflow should be listed right away [in this list](https://github.com/KittyCAD/modeling-app/actions/workflows/build-apps.yml?query=event%3Apush)). | After it runs you should just need the push the branch and open a PR. | ||||||
|  |  | ||||||
| #### 3. Manually test artifacts | #### 2. Create a Cut Release PR | ||||||
|  |  | ||||||
|  | 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. | ||||||
|  |  | ||||||
|  | #### 3. Manually test artifacts from the Cut Release PR | ||||||
|  |  | ||||||
| ##### Release builds | ##### Release builds | ||||||
|  |  | ||||||
| The release builds can be found under the `out-{arch}-{platform}` zip files, at the very bottom of the `build-apps` summary page for the workflow (triggered by the tag in 2.). | The release builds can be found under the `out-{platform}` zip, at the very bottom of the `build-publish-apps` summary 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 issue. | 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. | ||||||
|  |  | ||||||
| ##### Updater-test builds | ##### Updater-test builds | ||||||
|  |  | ||||||
| The other `build-apps` output in the release `build-apps` workflow (triggered by 2.) is `updater-test-{arch}-{platform}`. It's a semi-automated process: for macOS, Windows, and Linux, download the corresponding updater-test artifact file, install the app, run it, expect an updater prompt to a dummy v0.255.255, install it and check that the app comes back at that version.  | The other `build-publish-apps` output in Cut Release PRs is `updater-test-{platform}`. As we don't have a way to test this fully automatically, we have a semi-automated process. For macOS, Windows, and Linux, download the corresponding updater-test artifact file, install the app, run it, expect an updater prompt to a dummy v0.255.255, install it and check that the app comes back at that version.  | ||||||
|  |  | ||||||
| The only difference with these builds is that they point to a different update location on the release bucket, with this dummy v0.255.255 always available. This helps ensuring that the version we release will be able to update to the next one available. | The only difference with these builds is that they point to a different update location on the release bucket, with this dummy v0.255.255 always available. This helps ensuring that the version we release will be able to update to the next one available. | ||||||
|  |  | ||||||
| @ -174,17 +182,18 @@ If the prompt doesn't show up, start the app in command line to grab the electro | |||||||
| ./Zoo Modeling App-{version}-{arch}-linux.AppImage | ./Zoo Modeling App-{version}-{arch}-linux.AppImage | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| #### 4. Publish the release | #### 4. Merge the Cut Release PR | ||||||
|  |  | ||||||
| Head over to https://github.com/KittyCAD/modeling-app/releases/new, pick the newly created tag and type it in the _Release title_ field as well. | 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. | ||||||
|  |  | ||||||
| Hit _Generate release notes_ as a starting point to discuss the changelog in the issue. Once done, make sure _Set as the latest release_ is checked, and hit _Publish release_.  |  | ||||||
|  |  | ||||||
| A new `publish-apps-release` will kick in and you should be able to find it [here](https://github.com/KittyCAD/modeling-app/actions?query=event%3Arelease). On success, the files will be uploaded to the public bucket as well as to the GitHub release, and the announcement on Discord will be sent.  | #### 5. Publish the release | ||||||
|  |  | ||||||
| #### 5. Close the issue | 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_. | ||||||
|  |  | ||||||
| If everything is well and the release is out to the public, the issue tracking the release shall be closed. | #### 6. Profit | ||||||
|  |  | ||||||
|  | A new Action kicks in at https://github.com/KittyCAD/modeling-app/actions, which can be found under `release` event filter. | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Fuzzing the parser | ## Fuzzing the parser | ||||||
| @ -337,47 +346,13 @@ For individual testing: | |||||||
| yarn test abstractSyntaxTree -t "unexpected closed curly brace" --silent=false | yarn test abstractSyntaxTree -t "unexpected closed curly brace" --silent=false | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Which will run our suite of [Vitest unit](https://vitest.dev/) and [React Testing Library E2E](https://testing-library.com/docs/react-testing-library/intro) tests, in interactive mode by default. | Which will run our suite of [Vitest unit](https://vitest.dev/) and [React Testing Library E2E](https://testing-library.com/docs/react-testing-library/intro/) tests, in interactive mode by default. | ||||||
|  |  | ||||||
| ### Rust tests | ### Rust tests | ||||||
|  |  | ||||||
| **Dependencies** |  | ||||||
|  |  | ||||||
| - `KITTYCAD_API_TOKEN` |  | ||||||
| - `cargo-nextest` |  | ||||||
| - `just` |  | ||||||
|  |  | ||||||
| #### Setting KITTYCAD_API_TOKEN |  | ||||||
| Use the production zoo.dev token, set this environment variable before running the tests |  | ||||||
|  |  | ||||||
| #### Installing cargonextest |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| cd src/wasm-lib |  | ||||||
| cargo search cargo-nextest |  | ||||||
| cargo install cargo-nextest |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| #### just |  | ||||||
| install [`just`](https://github.com/casey/just?tab=readme-ov-file#pre-built-binaries) |  | ||||||
|  |  | ||||||
| #### Running the tests |  | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| # With just |  | ||||||
| # Make sure KITTYCAD_API_TOKEN=<prod zoo.dev token> is set |  | ||||||
| # Make sure you installed cargo-nextest |  | ||||||
| # Make sure you installed just |  | ||||||
| cd src/wasm-lib | cd src/wasm-lib | ||||||
| just test | KITTYCAD_API_TOKEN=XXX cargo test -- --test-threads=1 | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ```bash |  | ||||||
| # Without just |  | ||||||
| # Make sure KITTYCAD_API_TOKEN=<prod zoo.dev token> is set |  | ||||||
| # Make sure you installed cargo-nextest |  | ||||||
| cd src/wasm-lib |  | ||||||
| export RUST_BRACKTRACE="full" && cargo nextest run --workspace --test-threads=1 |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Where `XXX` is an API token from the production engine (NOT the dev environment). | Where `XXX` is an API token from the production engine (NOT the dev environment). | ||||||
| @ -422,6 +397,23 @@ yarn test:unit:local | |||||||
|  |  | ||||||
| #### E2E 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** | **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. | 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. | ||||||
| @ -467,9 +459,3 @@ PS: for the debug panel, the following JSON is useful for snapping the camera | |||||||
| ## 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). | ||||||
|  |  | ||||||
| ### Logging |  | ||||||
|  |  | ||||||
| To display logging (to the terminal or console) set `ZOO_LOG=1`. This will log some warnings and simple performance metrics. To view these in test runs, use `-- --nocapture`. |  | ||||||
|  |  | ||||||
| To enable memory metrics, build with `--features dhat-heap`. |  | ||||||
|  | |||||||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 119 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 259 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icon.icns
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon.icns
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								assets/icon.ico
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon.ico
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 114 KiB After Width: | Height: | Size: 183 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icon.png
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon.png
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 113 KiB After Width: | Height: | Size: 113 KiB | 
							
								
								
									
										
											BIN
										
									
								
								assets/icon@2x.icns
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/icon@2x.icns
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @ -22,5 +22,3 @@ 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. | ||||||
|  |  | ||||||
| - **Appearance**: Changing the appearance on a loft does not work. |  | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							| @ -36,15 +36,15 @@ filletRadius = 2 | |||||||
|  |  | ||||||
| mountingPlateSketch = startSketchOn("XY") | mountingPlateSketch = startSketchOn("XY") | ||||||
|   |> startProfileAt([-width / 2, -length / 2], %) |   |> startProfileAt([-width / 2, -length / 2], %) | ||||||
|   |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |   |> lineTo([width / 2, -length / 2], %, $edge1) | ||||||
|   |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) |   |> lineTo([width / 2, length / 2], %, $edge2) | ||||||
|   |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3) |   |> lineTo([-width / 2, length / 2], %, $edge3) | ||||||
|   |> close(tag = $edge4) |   |> close(%, $edge4) | ||||||
|  |  | ||||||
| mountingPlate = extrude(mountingPlateSketch, length = thickness) | mountingPlate = extrude(thickness, mountingPlateSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius = filletRadius, |        radius: filletRadius, | ||||||
|        tags = [ |        tags: [ | ||||||
|          getNextAdjacentEdge(edge1), |          getNextAdjacentEdge(edge1), | ||||||
|          getNextAdjacentEdge(edge2), |          getNextAdjacentEdge(edge2), | ||||||
|          getNextAdjacentEdge(edge3), |          getNextAdjacentEdge(edge3), | ||||||
| @ -63,16 +63,16 @@ filletRadius = 1 | |||||||
|  |  | ||||||
| mountingPlateSketch = startSketchOn("XY") | mountingPlateSketch = startSketchOn("XY") | ||||||
|   |> startProfileAt([-width / 2, -length / 2], %) |   |> startProfileAt([-width / 2, -length / 2], %) | ||||||
|   |> line(endAbsolute = [width / 2, -length / 2], tag = $edge1) |   |> lineTo([width / 2, -length / 2], %, $edge1) | ||||||
|   |> line(endAbsolute = [width / 2, length / 2], tag = $edge2) |   |> lineTo([width / 2, length / 2], %, $edge2) | ||||||
|   |> line(endAbsolute = [-width / 2, length / 2], tag = $edge3) |   |> lineTo([-width / 2, length / 2], %, $edge3) | ||||||
|   |> close(tag = $edge4) |   |> close(%, $edge4) | ||||||
|  |  | ||||||
| mountingPlate = extrude(mountingPlateSketch, length = thickness) | mountingPlate = extrude(thickness, mountingPlateSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius = filletRadius, |        radius: filletRadius, | ||||||
|        tolerance = 0.000001, |        tolerance: 0.000001, | ||||||
|        tags = [ |        tags: [ | ||||||
|          getNextAdjacentEdge(edge1), |          getNextAdjacentEdge(edge1), | ||||||
|          getNextAdjacentEdge(edge2), |          getNextAdjacentEdge(edge2), | ||||||
|          getNextAdjacentEdge(edge3), |          getNextAdjacentEdge(edge3), | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -29,17 +29,17 @@ getNextAdjacentEdge(tag: TagIdentifier) -> Uuid | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line(end = [10, 0]) |   |> line([10, 0], %) | ||||||
|   |> angledLine({ angle = 60, length = 10 }, %) |   |> angledLine({ angle: 60, length: 10 }, %) | ||||||
|   |> angledLine({ angle = 120, length = 10 }, %) |   |> angledLine({ angle: 120, length: 10 }, %) | ||||||
|   |> line(end = [-10, 0]) |   |> line([-10, 0], %) | ||||||
|   |> angledLine({ angle = 240, length = 10 }, %, $referenceEdge) |   |> angledLine({ angle: 240, length: 10 }, %, $referenceEdge) | ||||||
|   |> close() |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(exampleSketch, length = 5) | example = extrude(5, exampleSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius = 3, |        radius: 3, | ||||||
|        tags = [getNextAdjacentEdge(referenceEdge)] |        tags: [getNextAdjacentEdge(referenceEdge)] | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,17 +29,17 @@ getOppositeEdge(tag: TagIdentifier) -> Uuid | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line(end = [10, 0]) |   |> line([10, 0], %) | ||||||
|   |> angledLine({ angle = 60, length = 10 }, %) |   |> angledLine({ angle: 60, length: 10 }, %) | ||||||
|   |> angledLine({ angle = 120, length = 10 }, %) |   |> angledLine({ angle: 120, length: 10 }, %) | ||||||
|   |> line(end = [-10, 0]) |   |> line([-10, 0], %) | ||||||
|   |> angledLine({ angle = 240, length = 10 }, %, $referenceEdge) |   |> angledLine({ angle: 240, length: 10 }, %, $referenceEdge) | ||||||
|   |> close() |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(exampleSketch, length = 5) | example = extrude(5, exampleSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius = 3, |        radius: 3, | ||||||
|        tags = [getOppositeEdge(referenceEdge)] |        tags: [getOppositeEdge(referenceEdge)] | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
| @ -29,17 +29,17 @@ getPreviousAdjacentEdge(tag: TagIdentifier) -> Uuid | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line(end = [10, 0]) |   |> line([10, 0], %) | ||||||
|   |> angledLine({ angle = 60, length = 10 }, %) |   |> angledLine({ angle: 60, length: 10 }, %) | ||||||
|   |> angledLine({ angle = 120, length = 10 }, %) |   |> angledLine({ angle: 120, length: 10 }, %) | ||||||
|   |> line(end = [-10, 0]) |   |> line([-10, 0], %) | ||||||
|   |> angledLine({ angle = 240, length = 10 }, %, $referenceEdge) |   |> angledLine({ angle: 240, length: 10 }, %, $referenceEdge) | ||||||
|   |> close() |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(exampleSketch, length = 5) | example = extrude(5, exampleSketch) | ||||||
|   |> fillet({ |   |> fillet({ | ||||||
|        radius = 3, |        radius: 3, | ||||||
|        tags = [getPreviousAdjacentEdge(referenceEdge)] |        tags: [getPreviousAdjacentEdge(referenceEdge)] | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							| @ -31,11 +31,11 @@ hollow(thickness: number, solid: Solid) -> Solid | |||||||
| // Hollow a basic sketch. | // Hollow a basic sketch. | ||||||
| firstSketch = startSketchOn('XY') | firstSketch = startSketchOn('XY') | ||||||
|   |> startProfileAt([-12, 12], %) |   |> startProfileAt([-12, 12], %) | ||||||
|   |> line(end = [24, 0]) |   |> line([24, 0], %) | ||||||
|   |> line(end = [0, -24]) |   |> line([0, -24], %) | ||||||
|   |> line(end = [-24, 0]) |   |> line([-24, 0], %) | ||||||
|   |> close() |   |> close(%) | ||||||
|   |> extrude(length = 6) |   |> extrude(6, %) | ||||||
|   |> hollow(0.25, %) |   |> hollow(0.25, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @ -45,11 +45,11 @@ firstSketch = startSketchOn('XY') | |||||||
| // Hollow a basic sketch. | // Hollow a basic sketch. | ||||||
| firstSketch = startSketchOn('-XZ') | firstSketch = startSketchOn('-XZ') | ||||||
|   |> startProfileAt([-12, 12], %) |   |> startProfileAt([-12, 12], %) | ||||||
|   |> line(end = [24, 0]) |   |> line([24, 0], %) | ||||||
|   |> line(end = [0, -24]) |   |> line([0, -24], %) | ||||||
|   |> line(end = [-24, 0]) |   |> line([-24, 0], %) | ||||||
|   |> close() |   |> close(%) | ||||||
|   |> extrude(length = 6) |   |> extrude(6, %) | ||||||
|   |> hollow(0.5, %) |   |> hollow(0.5, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @ -60,25 +60,25 @@ firstSketch = startSketchOn('-XZ') | |||||||
| size = 100 | size = 100 | ||||||
| case = startSketchOn('-XZ') | case = startSketchOn('-XZ') | ||||||
|   |> startProfileAt([-size, -size], %) |   |> startProfileAt([-size, -size], %) | ||||||
|   |> line(end = [2 * size, 0]) |   |> line([2 * size, 0], %) | ||||||
|   |> line(end = [0, 2 * size]) |   |> line([0, 2 * size], %) | ||||||
|   |> tangentialArcTo([-size, size], %) |   |> tangentialArcTo([-size, size], %) | ||||||
|   |> close() |   |> close(%) | ||||||
|   |> extrude(length = 65) |   |> extrude(65, %) | ||||||
|  |  | ||||||
| thing1 = startSketchOn(case, 'end') | thing1 = startSketchOn(case, 'end') | ||||||
|   |> circle({ |   |> circle({ | ||||||
|        center = [-size / 2, -size / 2], |        center: [-size / 2, -size / 2], | ||||||
|        radius = 25 |        radius: 25 | ||||||
|      }, %) |      }, %) | ||||||
|   |> extrude(length = 50) |   |> extrude(50, %) | ||||||
|  |  | ||||||
| thing2 = startSketchOn(case, 'end') | thing2 = startSketchOn(case, 'end') | ||||||
|   |> circle({ |   |> circle({ | ||||||
|        center = [size / 2, -size / 2], |        center: [size / 2, -size / 2], | ||||||
|        radius = 25 |        radius: 25 | ||||||
|      }, %) |      }, %) | ||||||
|   |> extrude(length = 50) |   |> extrude(50, %) | ||||||
|  |  | ||||||
| hollow(0.5, case) | hollow(0.5, case) | ||||||
| ``` | ``` | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -7,7 +7,6 @@ layout: manual | |||||||
| ## Table of Contents | ## Table of Contents | ||||||
|  |  | ||||||
| * [Types](kcl/types) | * [Types](kcl/types) | ||||||
| * [Modules](kcl/modules) |  | ||||||
| * [Known Issues](kcl/KNOWN-ISSUES) | * [Known Issues](kcl/KNOWN-ISSUES) | ||||||
| * [`abs`](kcl/abs) | * [`abs`](kcl/abs) | ||||||
| * [`acos`](kcl/acos) | * [`acos`](kcl/acos) | ||||||
| @ -19,9 +18,7 @@ layout: manual | |||||||
| * [`angledLineThatIntersects`](kcl/angledLineThatIntersects) | * [`angledLineThatIntersects`](kcl/angledLineThatIntersects) | ||||||
| * [`angledLineToX`](kcl/angledLineToX) | * [`angledLineToX`](kcl/angledLineToX) | ||||||
| * [`angledLineToY`](kcl/angledLineToY) | * [`angledLineToY`](kcl/angledLineToY) | ||||||
| * [`appearance`](kcl/appearance) |  | ||||||
| * [`arc`](kcl/arc) | * [`arc`](kcl/arc) | ||||||
| * [`arcTo`](kcl/arcTo) |  | ||||||
| * [`asin`](kcl/asin) | * [`asin`](kcl/asin) | ||||||
| * [`assert`](kcl/assert) | * [`assert`](kcl/assert) | ||||||
| * [`assertEqual`](kcl/assertEqual) | * [`assertEqual`](kcl/assertEqual) | ||||||
| @ -30,12 +27,10 @@ layout: manual | |||||||
| * [`assertLessThan`](kcl/assertLessThan) | * [`assertLessThan`](kcl/assertLessThan) | ||||||
| * [`assertLessThanOrEq`](kcl/assertLessThanOrEq) | * [`assertLessThanOrEq`](kcl/assertLessThanOrEq) | ||||||
| * [`atan`](kcl/atan) | * [`atan`](kcl/atan) | ||||||
| * [`atan2`](kcl/atan2) |  | ||||||
| * [`bezierCurve`](kcl/bezierCurve) | * [`bezierCurve`](kcl/bezierCurve) | ||||||
| * [`ceil`](kcl/ceil) | * [`ceil`](kcl/ceil) | ||||||
| * [`chamfer`](kcl/chamfer) | * [`chamfer`](kcl/chamfer) | ||||||
| * [`circle`](kcl/circle) | * [`circle`](kcl/circle) | ||||||
| * [`circleThreePoint`](kcl/circleThreePoint) |  | ||||||
| * [`close`](kcl/close) | * [`close`](kcl/close) | ||||||
| * [`cm`](kcl/cm) | * [`cm`](kcl/cm) | ||||||
| * [`cos`](kcl/cos) | * [`cos`](kcl/cos) | ||||||
| @ -48,16 +43,18 @@ layout: manual | |||||||
| * [`getOppositeEdge`](kcl/getOppositeEdge) | * [`getOppositeEdge`](kcl/getOppositeEdge) | ||||||
| * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) | * [`getPreviousAdjacentEdge`](kcl/getPreviousAdjacentEdge) | ||||||
| * [`helix`](kcl/helix) | * [`helix`](kcl/helix) | ||||||
| * [`helixRevolutions`](kcl/helixRevolutions) |  | ||||||
| * [`hole`](kcl/hole) | * [`hole`](kcl/hole) | ||||||
| * [`hollow`](kcl/hollow) | * [`hollow`](kcl/hollow) | ||||||
|  | * [`import`](kcl/import) | ||||||
| * [`inch`](kcl/inch) | * [`inch`](kcl/inch) | ||||||
|  | * [`int`](kcl/int) | ||||||
| * [`lastSegX`](kcl/lastSegX) | * [`lastSegX`](kcl/lastSegX) | ||||||
| * [`lastSegY`](kcl/lastSegY) | * [`lastSegY`](kcl/lastSegY) | ||||||
| * [`legAngX`](kcl/legAngX) | * [`legAngX`](kcl/legAngX) | ||||||
| * [`legAngY`](kcl/legAngY) | * [`legAngY`](kcl/legAngY) | ||||||
| * [`legLen`](kcl/legLen) | * [`legLen`](kcl/legLen) | ||||||
| * [`line`](kcl/line) | * [`line`](kcl/line) | ||||||
|  | * [`lineTo`](kcl/lineTo) | ||||||
| * [`ln`](kcl/ln) | * [`ln`](kcl/ln) | ||||||
| * [`loft`](kcl/loft) | * [`loft`](kcl/loft) | ||||||
| * [`log`](kcl/log) | * [`log`](kcl/log) | ||||||
| @ -75,11 +72,9 @@ layout: manual | |||||||
| * [`patternLinear2d`](kcl/patternLinear2d) | * [`patternLinear2d`](kcl/patternLinear2d) | ||||||
| * [`patternLinear3d`](kcl/patternLinear3d) | * [`patternLinear3d`](kcl/patternLinear3d) | ||||||
| * [`patternTransform`](kcl/patternTransform) | * [`patternTransform`](kcl/patternTransform) | ||||||
| * [`patternTransform2d`](kcl/patternTransform2d) |  | ||||||
| * [`pi`](kcl/pi) | * [`pi`](kcl/pi) | ||||||
| * [`polar`](kcl/polar) | * [`polar`](kcl/polar) | ||||||
| * [`polygon`](kcl/polygon) | * [`polygon`](kcl/polygon) | ||||||
| * [`pop`](kcl/pop) |  | ||||||
| * [`pow`](kcl/pow) | * [`pow`](kcl/pow) | ||||||
| * [`profileStart`](kcl/profileStart) | * [`profileStart`](kcl/profileStart) | ||||||
| * [`profileStartX`](kcl/profileStartX) | * [`profileStartX`](kcl/profileStartX) | ||||||
| @ -88,23 +83,17 @@ layout: manual | |||||||
| * [`reduce`](kcl/reduce) | * [`reduce`](kcl/reduce) | ||||||
| * [`rem`](kcl/rem) | * [`rem`](kcl/rem) | ||||||
| * [`revolve`](kcl/revolve) | * [`revolve`](kcl/revolve) | ||||||
| * [`round`](kcl/round) |  | ||||||
| * [`segAng`](kcl/segAng) | * [`segAng`](kcl/segAng) | ||||||
| * [`segEnd`](kcl/segEnd) |  | ||||||
| * [`segEndX`](kcl/segEndX) | * [`segEndX`](kcl/segEndX) | ||||||
| * [`segEndY`](kcl/segEndY) | * [`segEndY`](kcl/segEndY) | ||||||
| * [`segLen`](kcl/segLen) | * [`segLen`](kcl/segLen) | ||||||
| * [`segStart`](kcl/segStart) |  | ||||||
| * [`segStartX`](kcl/segStartX) |  | ||||||
| * [`segStartY`](kcl/segStartY) |  | ||||||
| * [`shell`](kcl/shell) | * [`shell`](kcl/shell) | ||||||
| * [`sin`](kcl/sin) | * [`sin`](kcl/sin) | ||||||
| * [`sqrt`](kcl/sqrt) | * [`sqrt`](kcl/sqrt) | ||||||
| * [`startProfileAt`](kcl/startProfileAt) | * [`startProfileAt`](kcl/startProfileAt) | ||||||
|  | * [`startSketchAt`](kcl/startSketchAt) | ||||||
| * [`startSketchOn`](kcl/startSketchOn) | * [`startSketchOn`](kcl/startSketchOn) | ||||||
| * [`sweep`](kcl/sweep) |  | ||||||
| * [`tan`](kcl/tan) | * [`tan`](kcl/tan) | ||||||
| * [`tangentToEnd`](kcl/tangentToEnd) |  | ||||||
| * [`tangentialArc`](kcl/tangentialArc) | * [`tangentialArc`](kcl/tangentialArc) | ||||||
| * [`tangentialArcTo`](kcl/tangentialArcTo) | * [`tangentialArcTo`](kcl/tangentialArcTo) | ||||||
| * [`tangentialArcToRelative`](kcl/tangentialArcToRelative) | * [`tangentialArcToRelative`](kcl/tangentialArcToRelative) | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							| @ -29,9 +29,9 @@ map(array: [KclValue], map_fn: FunctionParam) -> [KclValue] | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| r = 10 // radius | r = 10 // radius | ||||||
| fn drawCircle(id) { | fn drawCircle = (id) => { | ||||||
|   return startSketchOn("XY") |   return startSketchOn("XY") | ||||||
|     |> circle({ center = [id * 2 * r, 0], radius = r }, %) |   |> circle({ center: [id * 2 * r, 0], radius: r }, %) | ||||||
| } | } | ||||||
|  |  | ||||||
| // Call `drawCircle`, passing in each element of the array. | // Call `drawCircle`, passing in each element of the array. | ||||||
| @ -45,9 +45,9 @@ circles = map([1..3], drawCircle) | |||||||
| ```js | ```js | ||||||
| r = 10 // radius | r = 10 // radius | ||||||
| // Call `map`, using an anonymous function instead of a named one. | // Call `map`, using an anonymous function instead of a named one. | ||||||
| circles = map([1..3], fn(id) { | circles = map([1..3], (id) => { | ||||||
|   return startSketchOn("XY") |   return startSketchOn("XY") | ||||||
|     |> circle({ center = [id * 2 * r, 0], radius = r }, %) |   |> circle({ center: [id * 2 * r, 0], radius: r }, %) | ||||||
| }) | }) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							| @ -1,59 +0,0 @@ | |||||||
| --- |  | ||||||
| title: "KCL Modules" |  | ||||||
| excerpt: "Documentation of modules for the KCL language for the Zoo Modeling App." |  | ||||||
| layout: manual |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| `KCL` allows splitting code up into multiple files.  Each file is somewhat |  | ||||||
| isolated from other files as a separate module. |  | ||||||
|  |  | ||||||
| When you define a function, you can use `export` before it to make it available |  | ||||||
| to other modules. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| // util.kcl |  | ||||||
| export fn increment(x) { |  | ||||||
|   return x + 1 |  | ||||||
| } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Other files in the project can now import functions that have been exported. |  | ||||||
| This makes them available to use in another file. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| // main.kcl |  | ||||||
| import increment from "util.kcl" |  | ||||||
|  |  | ||||||
| answer = increment(41) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Imported files _must_ be in the same project so that units are uniform across |  | ||||||
| modules. This means that it must be in the same directory. |  | ||||||
|  |  | ||||||
| Import statements must be at the top-level of a file. It is not allowed to have |  | ||||||
| an `import` statement inside a function or in the body of an if-else. |  | ||||||
|  |  | ||||||
| Multiple functions can be exported in a file. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| // util.kcl |  | ||||||
| export fn increment(x) { |  | ||||||
|   return x + 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export fn decrement(x) { |  | ||||||
|   return x - 1 |  | ||||||
| } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| When importing, you can import multiple functions at once. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| import increment, decrement from "util.kcl" |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Imported symbols can be renamed for convenience or to avoid name collisions. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| import increment as inc, decrement as dec from "util.kcl" |  | ||||||
| ``` |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -29,15 +29,15 @@ patternCircular3d(data: CircularPattern3dData, solid_set: SolidSet) -> [Solid] | |||||||
|  |  | ||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> circle({ center = [0, 0], radius = 1 }, %) |   |> circle({ center: [0, 0], radius: 1 }, %) | ||||||
|  |  | ||||||
| example = extrude(exampleSketch, length = -5) | example = extrude(-5, exampleSketch) | ||||||
|   |> patternCircular3d({ |   |> patternCircular3d({ | ||||||
|        axis = [1, -1, 0], |        axis: [1, -1, 0], | ||||||
|        center = [10, -20, 0], |        center: [10, -20, 0], | ||||||
|        instances = 11, |        instances: 11, | ||||||
|        arcDegrees = 360, |        arcDegrees: 360, | ||||||
|        rotateDuplicates = true |        rotateDuplicates: true | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -30,16 +30,16 @@ patternLinear3d(data: LinearPattern3dData, solid_set: SolidSet) -> [Solid] | |||||||
| ```js | ```js | ||||||
| exampleSketch = startSketchOn('XZ') | exampleSketch = startSketchOn('XZ') | ||||||
|   |> startProfileAt([0, 0], %) |   |> startProfileAt([0, 0], %) | ||||||
|   |> line(end = [0, 2]) |   |> line([0, 2], %) | ||||||
|   |> line(end = [3, 1]) |   |> line([3, 1], %) | ||||||
|   |> line(end = [0, -4]) |   |> line([0, -4], %) | ||||||
|   |> close() |   |> close(%) | ||||||
|  |  | ||||||
| example = extrude(exampleSketch, length = 1) | example = extrude(1, exampleSketch) | ||||||
|   |> patternLinear3d({ |   |> patternLinear3d({ | ||||||
|        axis = [1, 0, 1], |        axis: [1, 0, 1], | ||||||
|        instances = 7, |        instances: 7, | ||||||
|        distance = 6 |        distance: 6 | ||||||
|      }, %) |      }, %) | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | |||||||
										
											
												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
											
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	