Package Exports
- @scottybee84/mock-netsuite
- @scottybee84/mock-netsuite/dist/server.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@scottybee84/mock-netsuite) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
@scottybee84/mock-netsuite
Mock NetSuite API and SuiteScript host for learning and testing without a NetSuite account.
π₯ NEW in v0.2.0: Full SuiteScript hosting support! Run Suitelets, Restlets, User Events, and Map/Reduce scripts against a mock database.
Built with TypeScript and compiled to JavaScript for production use. Features auto-seeding and a CLI for easy setup.
Features
- π Mock NetSuite API - SuiteQL queries, record lookups
- π SuiteScript Host - Run Suitelets as web pages, Restlets as APIs
- π§ Mock N/* Modules - N/record, N/search, N/log, N/runtime, N/email, N/https
- π Training Ready - Perfect for NetSuite training courses
- π Zero Setup - Auto-seeds database, handles all dependencies
Prerequisites
β οΈ Important: Node.js Version
This package requires Node.js 18-22 (tested on 18/20/22). It will NOT work with Node.js 23+ due to better-sqlite3 ABI compatibility.
# Check your version
node --version
# If you need to switch (using nvm):
nvm install 20
nvm use 20
# Or install Volta for automatic switching:
# https://volta.sh
curl https://get.volta.sh | bash
volta pin node@20π‘ For consuming projects: Install Volta to automatically use the correct Node version when working with this package.
Quick Start (Global Install)
npm install -g @scottybee84/mock-netsuite
mock-netsuiteSuiteScript Hosting
# Run a Suitelet as a web page
mock-netsuite --suitelet path/to/my_suitelet.js
# Access at: http://localhost:3000/app/site/hosting/script/my_suitelet
# Run a Restlet as a REST API
mock-netsuite --restlet path/to/my_restlet.js
# Access at: http://localhost:3000/app/site/hosting/restlet/my_restletAPI Only
mock-netsuite
# Basic API endpoints at http://localhost:3000The CLI will automatically:
- β Check Node.js version compatibility
- π Start the Mock NetSuite API
- π Seed database with 500 customers + 2000 invoices (first run only)
- π Launch server on port 3000 (or PORT env var)
Development Workflow
π Quick Setup:
./dev.sh setup # One-time setup
./dev.sh watch # Auto-rebuild + restart on file changesπ Manual Commands:
npm install
npm run build # Compile TypeScript β dist/
npm run dev:watch # Watch TypeScript files for changes
npm run dev:cli # Build and test CLI
npm run reset # Reset database with fresh data
npm run dev # Build and start server onceπ― VS Code Integration:
Ctrl+Shift+Pβ "Tasks: Run Task" β "Watch TypeScript"Ctrl+Shift+Pβ "Tasks: Run Task" β "Start CLI"
π SuiteScript Hosting
Write real NetSuite SuiteScript code and test it locally! The mock environment includes:
Mock N/* Modules
- N/record - load(), create(), save(), submitFields()
- N/search - create(), run(), filters, columns
- N/log - debug(), audit(), error(), emergency()
- N/runtime - getCurrentUser(), getCurrentScript()
- N/email - send(), sendBulk() (mocked to console)
- N/https - get(), post(), put(), delete() (mocked responses)
Supported Script Types
- β Suitelets - Mounted as web endpoints
- β Restlets - Mounted as REST API endpoints
- π§ User Events - Execute with mock context
- π§ Map/Reduce - Execute phases against mock data
Example Usage
Create a Suitelet (my_suitelet.js):
/**
* @NApiVersion 2.1
* @NScriptType Suitelet
*/
import * as record from "N/record";
import * as log from "N/log";
export function onRequest(ctx) {
const customer = record.load({ type: "customer", id: 1 });
const name = customer.getValue({ fieldId: "companyname" });
log.audit("Customer Loaded", name);
ctx.response.write(`<h1>Customer: ${name}</h1>`);
}Run it:
mock-netsuite --suitelet my_suitelet.js
# Visit: http://localhost:3000/app/site/hosting/script/my_suiteletFor complete examples and advanced usage, see SUITESCRIPT-GUIDE.md.
π¦ Publishing:
./dev.sh publish # Automated: test β build β version β publish β git push
# OR manually:
npm run build && npm version patch && npm publishAPI Usage
Query Endpoint
POST http://localhost:3000/query/v1/suiteql
Content-Type: application/json
{
"query": "SELECT tranid,total,duedate,status FROM invoice WHERE status='Overdue' AND total > 10000 ORDER BY duedate ASC LIMIT 5;"
}Record Lookups
- Customer:
GET /record/v1/customer/{id} - Invoice:
GET /record/v1/invoice/{id}
Testing
# Health check
curl -s http://localhost:3000/health
# SuiteQL query example
curl -s -X POST http://localhost:3000/query/v1/suiteql \
-H "Content-Type: application/json" \
-d '{"query":"SELECT c.companyname, i.tranid, i.total FROM customer c JOIN invoice i ON c.id = i.customerid LIMIT 3;"}' | jqProject Structure
src/- TypeScript source filescli.ts- Command-line interface with auto-seedingserver.ts- Express API serverseed.ts- Database seeding script
dist/- Compiled JavaScript files (auto-generated)schema.sql- SQLite database schema with NetSuite-style field namestsconfig.json- TypeScript configuration
NetSuite-Style Fields
The database uses NetSuite internal ID conventions:
entityid(notentity_id)companyname(notcompany_name)tranid(nottran_id)customerid(notcustomer_id)duedate(notdue_date)datecreated(notcreated_at)
License
MIT - See LICENSE file for details. AI β SuiteQL without a NetSuite account.
Built with TypeScript and compiled to JavaScript for production use.
Development
npm install
npm run build # Compile TypeScript to dist/
npm run reset # Reset database with fresh data
npm run dev # Start server
npm run dev:watch # Watch TypeScript files for changesQuery
POST http://localhost:3000/query/v1/suiteql
{ "query": "SELECT tranid,total,duedate,status FROM invoice WHERE status='Overdue' AND total > 10000 ORDER BY duedate ASC LIMIT 20;" }
STEP 2 β Install, run, verify
In VS Code terminal:
npm i
npm run seed
npm run dev
Test (Terminal or Postman):
curl -s -X POST http://localhost:3000/query/v1/suiteql \
-H "Content-Type: application/json" \
-d '{"query":"SELECT tranid,total,duedate,status FROM invoice WHERE status=''Overdue'' AND total > 10000 ORDER BY duedate ASC LIMIT 5;"}' | jq
## Version Compatibility
**Node.js Support:** This package supports Node.js 18-22 (tested on 18/20/22) with fail-fast version checking.
**ABI Compatibility:** Uses `better-sqlite3` which requires native compilation. Version constraints ensure compatibility across the tested Node.js matrix.
**Auto-Version Management:**
- **Volta users:** Run `volta pin node@20` in your consuming project for automatic version switching
- **nvm users:** Use the included `.nvmrc` file with `nvm use`
- **CI/CD:** The `engines` field in package.json enforces version constraints
**Installation Flow:**
1. `preinstall` hook runs `scripts/check-node.js` for immediate version verification
2. `postinstall` hook rebuilds native modules for your specific Node version
3. Helpful error messages guide users to version management solutions
You should see an items array of invoices.
Back in GitHub Desktop: commit β βinit mock-netsuiteβ β Publish repository (public).