* chore: bump version to 2.22.9 Updated version number to trigger release workflow after n8n 1.118.1 update. Previous version 2.22.8 was already released on 2025-10-28, so the release workflow did not trigger when PR #393 was merged. Changes: - Bump package.json version from 2.22.8 to 2.22.9 - Update CHANGELOG.md with correct version and date Conceived by Romuald Członkowski - https://www.aiadvisors.pl/en 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com> * docs: update n8n update workflow with lessons learned Added new fast workflow section based on 2025-11-04 update experience: - CRITICAL: Check existing releases first to avoid version conflicts - Skip local tests - CI runs them anyway (saves 2-3 min) - Integration test failures with 'unauthorized' are infrastructure issues - Release workflow only triggers on version CHANGE - Updated time estimates for fast vs full workflow This will make future n8n updates smoother and faster. Conceived by Romuald Członkowski - https://www.aiadvisors.pl/en 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com> * fix: exclude versionCounter from workflow updates for n8n 1.118.1 n8n 1.118.1 returns versionCounter in GET /workflows/{id} responses but rejects it in PUT /workflows/{id} updates with the error: 'request/body must NOT have additional properties' This was causing all integration tests to fail in CI with n8n 1.118.1. Changes: - Added versionCounter to excluded properties in cleanWorkflowForUpdate() - Tested and verified fix works with n8n 1.118.1 test instance Fixes CI failures in PR #395 Conceived by Romuald Członkowski - https://www.aiadvisors.pl/en 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com> * chore: improve versionCounter fix with types and tests - Add versionCounter type definition to Workflow and WorkflowExport interfaces - Add comprehensive test coverage for versionCounter exclusion - Update CHANGELOG with detailed bug fix documentation Addresses code review feedback from PR #395 Conceived by Romuald Członkowski - https://www.aiadvisors.pl/en --------- Co-authored-by: Claude <noreply@anthropic.com>
8.6 KiB
n8n Update Process - Quick Reference
⚡ Recommended Fast Workflow (2025-11-04)
CRITICAL FIRST STEP: Check existing releases to avoid version conflicts!
# 1. CHECK EXISTING RELEASES FIRST (prevents version conflicts!)
gh release list | head -5
# Look at the latest version - your new version must be higher!
# 2. Switch to main and pull
git checkout main && git pull
# 3. Check for updates (dry run)
npm run update:n8n:check
# 4. Run update and skip tests (we'll test in CI)
yes y | npm run update:n8n
# 5. Create feature branch
git checkout -b update/n8n-X.X.X
# 6. Update version in package.json (must be HIGHER than latest release!)
# Edit: "version": "2.XX.X" (not the version from the release list!)
# 7. Update CHANGELOG.md
# - Change version number to match package.json
# - Update date to today
# - Update dependency versions
# 8. Update README badge
# Edit line 8: Change n8n version badge to new n8n version
# 9. Commit and push
git add -A
git commit -m "chore: update n8n to X.X.X and bump version to 2.XX.X
- Updated n8n from X.X.X to X.X.X
- Updated n8n-core from X.X.X to X.X.X
- Updated n8n-workflow from X.X.X to X.X.X
- Updated @n8n/n8n-nodes-langchain from X.X.X to X.X.X
- Rebuilt node database with XXX nodes (XXX from n8n-nodes-base, XXX from @n8n/n8n-nodes-langchain)
- Updated README badge with new n8n version
- Updated CHANGELOG with dependency changes
Conceived by Romuald Członkowski - https://www.aiadvisors.pl/en
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude <noreply@anthropic.com>"
git push -u origin update/n8n-X.X.X
# 10. Create PR
gh pr create --title "chore: update n8n to X.X.X" --body "Updates n8n and all related dependencies to the latest versions..."
# 11. After PR is merged, verify release triggered
gh release list | head -1
# If the new version appears, you're done!
# If not, the version might have already been released - bump version again and create new PR
Why This Workflow?
✅ Fast: Skip local tests (2-3 min saved) - CI runs them anyway ✅ Safe: Unit tests in CI verify compatibility ✅ Clean: All changes in one PR with proper tracking ✅ Automatic: Release workflow triggers on merge if version is new
Common Issues
Problem: Release workflow doesn't trigger after merge
Cause: Version number was already released (check gh release list)
Solution: Create new PR bumping version by one patch number
Problem: Integration tests fail in CI with "unauthorized" Cause: n8n test instance credentials expired (infrastructure issue) Solution: Ignore if unit tests pass - this is not a code problem
Problem: CI takes 8+ minutes Reason: Integration tests need live n8n instance (slow) Normal: Unit tests (~2 min) + integration tests (~6 min) = ~8 min total
Quick One-Command Update
For a complete update with tests and publish preparation:
npm run update:all
This single command will:
- ✅ Check for n8n updates and ask for confirmation
- ✅ Update all n8n dependencies to latest compatible versions
- ✅ Run all 1,182 tests (933 unit + 249 integration)
- ✅ Validate critical nodes
- ✅ Build the project
- ✅ Bump the version
- ✅ Update README badges
- ✅ Prepare everything for npm publish
- ✅ Create a comprehensive commit
Manual Steps (if needed)
Quick Steps to Update n8n
# 1. Update n8n dependencies automatically
npm run update:n8n
# 2. Run tests
npm test
# 3. Validate the update
npm run validate
# 4. Build
npm run build
# 5. Bump version
npm version patch
# 6. Update README badges manually
# - Update version badge
# - Update n8n version badge
# 7. Commit and push
git add -A
git commit -m "chore: update n8n to vX.X.X
- Updated n8n from X.X.X to X.X.X
- Updated n8n-core from X.X.X to X.X.X
- Updated n8n-workflow from X.X.X to X.X.X
- Updated @n8n/n8n-nodes-langchain from X.X.X to X.X.X
- Rebuilt node database with XXX nodes
- Sanitized XXX workflow templates (if present)
- All 1,182 tests passing (933 unit, 249 integration)
- All validation tests passing
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>"
git push origin main
What the Commands Do
npm run update:all
This comprehensive command:
- Checks current branch and git status
- Shows current versions and checks for updates
- Updates all n8n dependencies to compatible versions
- Runs the complete test suite (NEW!)
- Validates critical nodes
- Builds the project
- Bumps the patch version
- Updates version badges in README
- Creates a detailed commit with all changes
- Provides next steps for GitHub release and npm publish
npm run update:n8n
This command:
- Checks for the latest n8n version
- Updates n8n and all its required dependencies (n8n-core, n8n-workflow, @n8n/n8n-nodes-langchain)
- Runs
npm installto update package-lock.json - Automatically rebuilds the node database
- Sanitizes any workflow templates to remove API tokens
- Shows you exactly what versions were updated
npm run validate
- Validates critical nodes (httpRequest, code, slack, agent)
- Shows database statistics
- Confirms everything is working correctly
npm test
- Runs all 1,182 tests
- Unit tests: 933 tests across 30 files
- Integration tests: 249 tests across 14 files
- Must pass before publishing!
Important Notes
- ALWAYS check existing releases first - Use
gh release listto see what versions are already released. Your new version must be higher! - Release workflow only triggers on version CHANGE - If you merge a PR with an already-released version (e.g., 2.22.8), the workflow won't run. You'll need to bump to a new version (e.g., 2.22.9) and create another PR.
- Integration test failures in CI are usually infrastructure issues - If unit tests pass but integration tests fail with "unauthorized", this is typically because the test n8n instance credentials need updating. The code itself is fine.
- Skip local tests - let CI handle them - Running tests locally adds 2-3 minutes with no benefit since CI runs them anyway. The fast workflow skips local tests.
- The update script is smart - It automatically syncs all n8n dependencies to compatible versions
- Database rebuild is automatic - The update script handles this for you
- Template sanitization is automatic - Any API tokens in workflow templates are replaced with placeholders
- Docker image builds automatically - Pushing to GitHub triggers the workflow
GitHub Push Protection
As of July 2025, GitHub's push protection may block database pushes if they contain API tokens in workflow templates. Our rebuild process now automatically sanitizes these tokens, but if you encounter push protection errors:
- Make sure you've run the latest rebuild with
npm run rebuild - Verify sanitization with
npm run sanitize:templates - If push is still blocked, use the GitHub web interface to review and allow the push
Time Estimate
Fast Workflow (Recommended)
- Local work: ~2-3 minutes
- npm install and database rebuild: ~2-3 minutes
- File edits (CHANGELOG, README, package.json): ~30 seconds
- Git operations (commit, push, create PR): ~30 seconds
- CI testing after PR creation: ~8-10 minutes (runs automatically)
- Unit tests: ~2 minutes
- Integration tests: ~6 minutes (may fail with infrastructure issues - ignore if unit tests pass)
- Other checks: ~1 minute
Total hands-on time: ~3 minutes (then wait for CI)
Full Workflow with Local Tests
- Total time: ~5-7 minutes
- Test suite: ~2.5 minutes
- npm install and database rebuild: ~2-3 minutes
- The rest: seconds
Note: The fast workflow is recommended since CI runs the same tests anyway.
Troubleshooting
If tests fail:
- Check the test output for specific failures
- Run
npm run test:unitornpm run test:integrationseparately - Fix any issues before proceeding with the update
If validation fails:
- Check the error message - usually it's a node type reference issue
- The update script handles most compatibility issues automatically
- If needed, check the GitHub Actions logs for the dependency update workflow
Alternative: Check First
To see what would be updated without making changes:
npm run update:n8n:check
This shows you the available updates without modifying anything.
Publishing to npm
After updating:
# Prepare for publish (runs tests automatically)
npm run prepare:publish
# Follow the instructions to publish with OTP
cd npm-publish-temp
npm publish --otp=YOUR_OTP_CODE
Creating a GitHub Release
After pushing:
gh release create vX.X.X --title "vX.X.X" --notes "Updated n8n to vX.X.X"