forked from fastify/fastify-cli
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: add support for typescript and esm generation (fastify#577)
This commit will be amended with better implementation soon.
- Loading branch information
1 parent
ec71989
commit 5299eb1
Showing
21 changed files
with
532 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,3 +4,4 @@ jobs: 1 | |
reporter: terse | ||
check-coverage: false | ||
timeout: 60 | ||
test-ignore: templates/app-ts-esm/.* |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# Getting Started with [Fastify-CLI](https://www.npmjs.com/package/fastify-cli) | ||
This project was bootstrapped with Fastify-CLI. | ||
|
||
## Available Scripts | ||
|
||
In the project directory, you can run: | ||
|
||
### `npm run dev` | ||
|
||
To start the app in dev mode.\ | ||
Open [http://localhost:3000](http://localhost:3000) to view it in the browser. | ||
|
||
### `npm start` | ||
|
||
For production mode | ||
|
||
### `npm run test` | ||
|
||
Run the test cases. | ||
|
||
## Learn More | ||
|
||
To learn Fastify, check out the [Fastify documentation](https://www.fastify.io/docs/latest/). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
# Logs | ||
logs | ||
*.log | ||
npm-debug.log* | ||
|
||
# Runtime data | ||
pids | ||
*.pid | ||
*.seed | ||
|
||
# Directory for instrumented libs generated by jscoverage/JSCover | ||
lib-cov | ||
|
||
# Coverage directory used by tools like istanbul | ||
coverage | ||
|
||
# nyc test coverage | ||
.nyc_output | ||
|
||
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) | ||
.grunt | ||
|
||
# node-waf configuration | ||
.lock-wscript | ||
|
||
# Compiled binary addons (http://nodejs.org/api/addons.html) | ||
build/Release | ||
|
||
# Dependency directories | ||
node_modules | ||
jspm_packages | ||
|
||
# Optional npm cache directory | ||
.npm | ||
|
||
# Optional REPL history | ||
.node_repl_history | ||
|
||
# 0x | ||
profile-* | ||
|
||
# mac files | ||
.DS_Store | ||
|
||
# vim swap files | ||
*.swp | ||
|
||
# webstorm | ||
.idea | ||
|
||
# vscode | ||
.vscode | ||
*code-workspace | ||
|
||
# clinic | ||
profile* | ||
*clinic* | ||
*flamegraph* | ||
|
||
# generated code | ||
examples/typescript-server.js | ||
test/types/index.js | ||
|
||
# compiled app | ||
dist |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
test-env: [ | ||
TS_NODE_FILES=true, | ||
TS_NODE_PROJECT=./test/tsconfig.json | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
{ | ||
"type": "module" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
import * as path from 'path'; | ||
import AutoLoad, {AutoloadPluginOptions} from '@fastify/autoload'; | ||
import { FastifyPluginAsync } from 'fastify'; | ||
import { fileURLToPath } from 'url' | ||
|
||
const __filename = fileURLToPath(import.meta.url) | ||
const __dirname = path.dirname(__filename) | ||
|
||
export type AppOptions = { | ||
// Place your custom options for app below here. | ||
} & Partial<AutoloadPluginOptions>; | ||
|
||
|
||
// Pass --options via CLI arguments in command to enable these options. | ||
const options: AppOptions = { | ||
} | ||
|
||
const app: FastifyPluginAsync<AppOptions> = async ( | ||
fastify, | ||
opts | ||
): Promise<void> => { | ||
// Place here your custom code! | ||
|
||
// Do not touch the following lines | ||
|
||
// This loads all plugins defined in plugins | ||
// those should be support plugins that are reused | ||
// through your application | ||
void fastify.register(AutoLoad, { | ||
dir: path.join(__dirname, 'plugins'), | ||
options: opts, | ||
forceESM: true | ||
}) | ||
|
||
// This loads all plugins defined in routes | ||
// define your routes in one of these | ||
void fastify.register(AutoLoad, { | ||
dir: path.join(__dirname, 'routes'), | ||
options: opts, | ||
forceESM: true | ||
}) | ||
|
||
}; | ||
|
||
export default app; | ||
export { app, options } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# Plugins Folder | ||
|
||
Plugins define behavior that is common to all the routes in your | ||
application. Authentication, caching, templates, and all the other cross | ||
cutting concerns should be handled by plugins placed in this folder. | ||
|
||
Files in this folder are typically defined through the | ||
[`fastify-plugin`](https://github.com/fastify/fastify-plugin) module, | ||
making them non-encapsulated. They can define decorators and set hooks | ||
that will then be used in the rest of your application. | ||
|
||
Check out: | ||
|
||
* [The hitchhiker's guide to plugins](https://www.fastify.io/docs/latest/Guides/Plugins-Guide/) | ||
* [Fastify decorators](https://www.fastify.io/docs/latest/Reference/Decorators/). | ||
* [Fastify lifecycle](https://www.fastify.io/docs/latest/Reference/Lifecycle/). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import fp from 'fastify-plugin' | ||
import sensible, { SensibleOptions } from '@fastify/sensible' | ||
|
||
/** | ||
* This plugins adds some utilities to handle http errors | ||
* | ||
* @see https://github.com/fastify/fastify-sensible | ||
*/ | ||
export default fp<SensibleOptions>(async (fastify) => { | ||
fastify.register(sensible) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
import fp from 'fastify-plugin' | ||
|
||
export interface SupportPluginOptions { | ||
// Specify Support plugin options here | ||
} | ||
|
||
// The use of fastify-plugin is required to be able | ||
// to export the decorators to the outer scope | ||
export default fp<SupportPluginOptions>(async (fastify, opts) => { | ||
fastify.decorate('someSupport', function () { | ||
return 'hugs' | ||
}) | ||
}) | ||
|
||
// When using .decorate you have to specify added properties for Typescript | ||
declare module 'fastify' { | ||
export interface FastifyInstance { | ||
someSupport(): string; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
# Routes Folder | ||
|
||
Routes define endpoints within your application. Fastify provides an | ||
easy path to a microservice architecture, in the future you might want | ||
to independently deploy some of those. | ||
|
||
In this folder you should define all the routes that define the endpoints | ||
of your web application. | ||
Each service is a [Fastify | ||
plugin](https://www.fastify.io/docs/latest/Reference/Plugins/), it is | ||
encapsulated (it can have its own independent plugins) and it is | ||
typically stored in a file; be careful to group your routes logically, | ||
e.g. all `/users` routes in a `users.js` file. We have added | ||
a `root.js` file for you with a '/' root added. | ||
|
||
If a single file become too large, create a folder and add a `index.js` file there: | ||
this file must be a Fastify plugin, and it will be loaded automatically | ||
by the application. You can now add as many files as you want inside that folder. | ||
In this way you can create complex routes within a single monolith, | ||
and eventually extract them. | ||
|
||
If you need to share functionality between routes, place that | ||
functionality into the `plugins` folder, and share it via | ||
[decorators](https://www.fastify.io/docs/latest/Reference/Decorators/). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
import { FastifyPluginAsync } from "fastify" | ||
|
||
const example: FastifyPluginAsync = async (fastify, opts): Promise<void> => { | ||
fastify.get('/', async function (request, reply) { | ||
return 'this is an example' | ||
}) | ||
} | ||
|
||
export default example; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
import { FastifyPluginAsync } from 'fastify' | ||
|
||
const root: FastifyPluginAsync = async (fastify, opts): Promise<void> => { | ||
fastify.get('/', async function (request, reply) { | ||
return { root: true } | ||
}) | ||
} | ||
|
||
export default root; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
// This file contains code that we reuse between our tests. | ||
// @ts-ignore | ||
import helper from 'fastify-cli/helper.js' | ||
import * as path from 'path' | ||
import * as tap from 'tap'; | ||
import { fileURLToPath } from 'url' | ||
|
||
|
||
export type Test = typeof tap['Test']['prototype']; | ||
|
||
const __filename = fileURLToPath(import.meta.url) | ||
const __dirname = path.dirname(__filename) | ||
const AppPath = path.join(__dirname, '..', 'src', 'app.ts') | ||
|
||
// Fill in this config with all the configurations | ||
// needed for testing the application | ||
async function config () { | ||
return {} | ||
} | ||
|
||
// Automatically build and tear down our instance | ||
async function build (t: Test) { | ||
// you can set all the options supported by the fastify CLI command | ||
const argv = [AppPath] | ||
|
||
// fastify-plugin ensures that all decorators | ||
// are exposed for testing purposes, this is | ||
// different from the production setup | ||
const app = await helper.build(argv, await config()) | ||
|
||
// Tear down our app after we are done | ||
t.teardown(() => void app.close()) | ||
|
||
return app | ||
} | ||
|
||
export { | ||
config, | ||
build | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import { test } from 'tap' | ||
import Fastify from 'fastify' | ||
import Support from '../../src/plugins/support.js' | ||
|
||
test('support works standalone', async (t) => { | ||
const fastify = Fastify() | ||
void fastify.register(Support) | ||
await fastify.ready() | ||
|
||
t.equal(fastify.someSupport(), 'hugs') | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
import { test } from 'tap' | ||
import { build } from '../helper.js' | ||
|
||
test('example is loaded', async (t) => { | ||
const app = await build(t) | ||
|
||
const res = await app.inject({ | ||
url: '/example' | ||
}) | ||
|
||
t.equal(res.payload, 'this is an example') | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import { test } from 'tap' | ||
import { build } from '../helper.js' | ||
|
||
test('default root route', async (t) => { | ||
const app = await build(t) | ||
|
||
const res = await app.inject({ | ||
url: '/' | ||
}) | ||
t.same(JSON.parse(res.payload), { root: true }) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
{ | ||
"extends": "../tsconfig.json", | ||
"compilerOptions": { | ||
"baseUrl": ".", | ||
"noEmit": false | ||
}, | ||
"include": ["../src/**/*.ts", "**/*.ts"] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
{ | ||
"extends": "fastify-tsconfig", | ||
"compilerOptions": { | ||
"outDir": "dist", | ||
"sourceMap": true, | ||
"moduleResolution": "Node16", | ||
"module": "ES2022", | ||
"esModuleInterop": true | ||
}, | ||
"include": ["src/**/*.ts"] | ||
} |
Oops, something went wrong.