diff --git a/assets/.github/ISSUE_TEMPLATE/BUG-REPORT.md b/assets/.github/ISSUE_TEMPLATE/BUG-REPORT.md deleted file mode 100644 index 5094c17..0000000 --- a/assets/.github/ISSUE_TEMPLATE/BUG-REPORT.md +++ /dev/null @@ -1,22 +0,0 @@ ---- -name: Bug report -about: File a bug report for any behavior that you believe is unintentional or problematic -title: "[BUG]" -labels: bug -assignees: '' - ---- - -## Describe the bug -Put a clear and concise description of what the bug is. This should be short and to the point, not to exceed more than a paragraph. Put the details inside your reproduction steps. - -## Reproduction -Make an easy-to-follow guide on how to reproduce it. Does it happen all the time? Will specific features affect reproduction? All these questions should be answered for a good issue. - -This is a good place to put rbxl files or scripts that help explain your reproduction steps. - -## Expected Behavior -What you expect to happen - -## Actual Behavior -What actually happens \ No newline at end of file diff --git a/assets/.github/ISSUE_TEMPLATE/DOCUMENTATION.md b/assets/.github/ISSUE_TEMPLATE/DOCUMENTATION.md deleted file mode 100644 index 0fbfcf4..0000000 --- a/assets/.github/ISSUE_TEMPLATE/DOCUMENTATION.md +++ /dev/null @@ -1,14 +0,0 @@ ---- -name: Documentation -about: Open an issue to add, change, or otherwise modify any part of the documentation. -title: "[DOCS]" -labels: documentation -assignees: '' - ---- - -## Which Sections Does This Issue Cover? -[Put sections (e.g. Query Concepts), page links, etc as necessary] - -## What Needs To Change? -What specifically needs to change and what suggestions do you have to change it? \ No newline at end of file diff --git a/assets/.github/ISSUE_TEMPLATE/FEATURE-REQUEST.md b/assets/.github/ISSUE_TEMPLATE/FEATURE-REQUEST.md deleted file mode 100644 index 7559dc9..0000000 --- a/assets/.github/ISSUE_TEMPLATE/FEATURE-REQUEST.md +++ /dev/null @@ -1,27 +0,0 @@ ---- -name: Feature Request -about: File a feature request for something you believe should be added to Jecs -title: "[FEATURE]" -labels: enhancement -assignees: '' - ---- - -## Describe your Feature - -You should explain your feature here, and the motivation for why you want it. - -## Implementation - -Explain how you would implement your feature here. Provide relevant API examples and such here (if applicable). - -## Alternatives - -What other alternative implementations or otherwise relevant information is important to why you decided to go with this specific implementation? - -## Considerations - -Some questions that need to be answered include the following: -- Will old code break in response to this feature? -- What are the performance impacts with this feature (if any)? -- How is it useful to include? diff --git a/assets/.github/PULL_REQUEST_TEMPLATE.md b/assets/.github/PULL_REQUEST_TEMPLATE.md deleted file mode 100644 index 349788c..0000000 --- a/assets/.github/PULL_REQUEST_TEMPLATE.md +++ /dev/null @@ -1,15 +0,0 @@ -## Brief Description of your Changes. - -Describe what you did here. Additionally, you should link any relevant issues within this section. If there is no corresponding issue, you should include relevant information (repro steps, motivation, etc) here. - -## Impact of your Changes - -What implications will this have on the project? Will there be altered behavior or performance with this change? - -## Tests Performed - -What have you done to ensure this change has the least possible impact on the project? - -## Additional Comments - -Anything else you feel is relevant. \ No newline at end of file diff --git a/assets/.github/workflows/analysis.yaml b/assets/.github/workflows/analysis.yaml deleted file mode 100644 index 18da7bc..0000000 --- a/assets/.github/workflows/analysis.yaml +++ /dev/null @@ -1,19 +0,0 @@ -name: analysis - -on: [push, pull_request, workflow_dispatch] - -jobs: - run: - name: Run Luau Analyze - runs-on: ubuntu-latest - - steps: - - name: Checkout Project - uses: actions/checkout@v4 - - - name: Install Luau - uses: encodedvenom/install-luau@v2.1 - - - name: Analyze - run: | - output=$(luau-analyze src || true) # Suppress errors for now. diff --git a/assets/.github/workflows/dependabot.yml b/assets/.github/workflows/dependabot.yml deleted file mode 100644 index 17f20b6..0000000 --- a/assets/.github/workflows/dependabot.yml +++ /dev/null @@ -1,11 +0,0 @@ ---- -version: 2 -updates: - - package-ecosystem: "github-actions" - directory: "/" - schedule: - interval: "daily" - - package-ecosystem: npm - directory: "/" - schedule: - interval: "daily" diff --git a/assets/.github/workflows/deploy-docs.yaml b/assets/.github/workflows/deploy-docs.yaml deleted file mode 100644 index 41c68dc..0000000 --- a/assets/.github/workflows/deploy-docs.yaml +++ /dev/null @@ -1,64 +0,0 @@ -# Sample workflow for building and deploying a VitePress site to GitHub Pages -# -name: deploy-docs - -on: - # Runs on pushes targeting the `main` branch. Change this to `master` if you're - # using the `master` branch as the default branch. - push: - branches: [main] - - # Allows you to run this workflow manually from the Actions tab - workflow_dispatch: - -# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages -permissions: - contents: read - pages: write - id-token: write - -# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. -# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete. -concurrency: - group: pages - cancel-in-progress: false - -jobs: - # Build job - build: - runs-on: ubuntu-latest - steps: - - name: Checkout - uses: actions/checkout@v4 - with: - fetch-depth: 0 # Not needed if lastUpdated is not enabled - # - uses: pnpm/action-setup@v3 # Uncomment this if you're using pnpm - # - uses: oven-sh/setup-bun@v1 # Uncomment this if you're using Bun - - name: Setup Node - uses: actions/setup-node@v4 - with: - node-version: 20 - cache: npm # or pnpm / yarn - - name: Setup Pages - uses: actions/configure-pages@v4 - - name: Install dependencies - run: npm ci # or pnpm install / yarn install / bun install - - name: Build with VitePress - run: npm run docs:build # or pnpm docs:build / yarn docs:build / bun run docs:build - - name: Upload artifact - uses: actions/upload-pages-artifact@v3 - with: - path: docs/.vitepress/dist - - # Deployment job - deploy: - environment: - name: github-pages - url: ${{ steps.deployment.outputs.page_url }} - needs: build - runs-on: ubuntu-latest - name: Deploy - steps: - - name: Deploy to GitHub Pages - id: deployment - uses: actions/deploy-pages@v4 diff --git a/assets/.github/workflows/publish-npm.yml b/assets/.github/workflows/publish-npm.yml deleted file mode 100644 index bce339d..0000000 --- a/assets/.github/workflows/publish-npm.yml +++ /dev/null @@ -1,17 +0,0 @@ -name: publish-npm - -on: - push: - branches: [main] - -jobs: - publish: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-node@v3 - with: - node-version: "20" - - uses: JS-DevTools/npm-publish@v3 - with: - token: ${{ secrets.NPM_AUTH_TOKEN }} diff --git a/assets/.github/workflows/release.yaml b/assets/.github/workflows/release.yaml deleted file mode 100644 index a423627..0000000 --- a/assets/.github/workflows/release.yaml +++ /dev/null @@ -1,71 +0,0 @@ -name: release - -on: - push: - tags: ["v*"] - -jobs: - build: - name: Build - runs-on: ubuntu-latest - steps: - - name: Checkout Project - uses: actions/checkout@v4 - - - name: Install Rokit - uses: CompeyDev/setup-rokit@v0.1.2 - - - name: Install Dependencies - run: wally install - - - name: Build - run: rojo build --output build.rbxm default.project.json - - - name: Upload Build Artifact - uses: actions/upload-artifact@v3 - with: - name: build - path: build.rbxm - - release: - name: Release - needs: [build] - runs-on: ubuntu-latest - permissions: - contents: write - steps: - - name: Checkout Project - uses: actions/checkout@v4 - - - name: Download Jecs Build - uses: actions/download-artifact@v3 - with: - name: build - path: build - - - name: Rename Build - run: mv build/build.rbxm jecs.rbxm - - - name: Create Release - uses: softprops/action-gh-release@v1 - with: - name: Jecs ${{ github.ref_name }} - files: | - jecs.rbxm - - publish: - name: Publish - needs: [release] - runs-on: ubuntu-latest - steps: - - name: Checkout Project - uses: actions/checkout@v4 - - - name: Install Rokit - uses: CompeyDev/setup-rokit@v0.1.2 - - - name: Wally Login - run: wally login --token ${{ secrets.WALLY_AUTH_TOKEN }} - - - name: Publish - run: wally publish diff --git a/assets/.github/workflows/unit-testing.yaml b/assets/.github/workflows/unit-testing.yaml deleted file mode 100644 index 1dbf6f7..0000000 --- a/assets/.github/workflows/unit-testing.yaml +++ /dev/null @@ -1,31 +0,0 @@ -name: unit-testing - -on: [push, pull_request, workflow_dispatch] - -jobs: - run: - name: Run Luau Tests - runs-on: ubuntu-latest - timeout-minutes: 2 - - steps: - - name: Checkout Project - uses: actions/checkout@v4 - - - name: Install Luau - uses: encodedvenom/install-luau@v4.3 - with: - version: "latest" - verbose: "true" - - - name: Run Unit Tests - id: run_tests - run: | - output=$(luau test/tests.luau) - echo "$output" - if [[ "$output" == *"0 fails"* ]]; then - echo "Unit Tests Passed" - else - echo "Error: One or More Unit Tests Failed." - exit 1 - fi diff --git a/tools/testkit.luau b/tools/testkit.luau index 4b48202..7af2c53 100644 --- a/tools/testkit.luau +++ b/tools/testkit.luau @@ -112,6 +112,7 @@ type Test = { trace: string, }?, focus: boolean, + fn: () -> () } type Case = { @@ -231,7 +232,9 @@ local function TEST(name: string, fn: () -> ()) fn = fn } - table.insert(tests, test) + local t = test + + table.insert(tests, t) end local function FOCUS() @@ -258,22 +261,22 @@ local function FINISH(): boolean continue end test = t - fn = t.fn + local fn = t.fn local start = os.clock() local err - local success = xpcall(fn, function(m: string) + local ok = xpcall(fn, function(m: string) err = { message = m, trace = debug.traceback(nil, 2) } end) - test.duration = os.clock() - start + t.duration = os.clock() - start - if not test.case then + if not t.case then CASE("") end - assert(test.case, "no active case") + assert(t.case, "no active case") - if not success then - test.case.result = ERROR - test.error = err + if not ok then + t.case.result = ERROR + t.error = err end collectgarbage() end