Add basic non blocking CI workflow. (#21)

This commit is contained in:
Allen Hutchison 2025-04-18 10:20:39 -07:00 committed by GitHub
parent 97db77997f
commit 7878f54043
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 57 additions and 1 deletions

55
.github/workflows/ci.yml vendored Normal file
View File

@ -0,0 +1,55 @@
# .github/workflows/ci.yml
name: Gemini Code CI
on:
push:
branches: [ main ] # Run on pushes to the main branch
pull_request:
branches: [ main ] # Run on pull requests targeting the main branch
jobs:
build_and_test:
name: Build and Test
runs-on: ubuntu-latest
strategy:
matrix:
# Specify the Node.js versions you want to test against
node-version: [ 20.x ] # You can add more like [18.x, 20.x]
steps:
# 1. Checkout Code
- name: Checkout repository
uses: actions/checkout@v4
# 2. Setup Node.js Environment
- name: Set up Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
cache: 'npm' # Enable caching for npm dependencies (speeds up subsequent runs)
# 3. Install Dependencies
# Use 'ci' for cleaner, faster, deterministic installs based on lockfile
- name: Install dependencies
run: npm ci
# 4. Linting
- name: Run linter
run: npm run lint
# 5. Type Checking
- name: Run type check
run: npm run typecheck # Or: tsc --noEmit
# 6. Build
# Optional if your tests run directly on TS files (e.g., using ts-jest, ts-node)
# But usually good practice to ensure the build itself works.
- name: Build project
run: npm run build
# 7. Testing
# Uncomment when we have tests.
#- name: Run tests
# run: npm test

View File

@ -9,8 +9,9 @@
"scripts": {
"build": "npm run build --workspaces",
"test": "npm run test --workspaces",
"lint": "eslint . --ext .ts,.tsx",
"typecheck": "tsc --noEmit --jsx react",
"start": "node ./scripts/check-build-status.js && npm run start --workspace=gemini-code-cli -- \"$@\"",
"lint": "eslint .",
"format": "prettier --write ."
},
"devDependencies": {