Skip to content

Fastify server leveraging swc-node for transpilation and Jest for testing

License

Notifications You must be signed in to change notification settings

mattfsourcecode/fastify-swc-typescript-server

Repository files navigation

Fastify SWC TypeScript Server

Overview

This project leverages Fastify, TypeScript, and SWC to build a high-performance, scalable server. Fastify offers unmatched scalability and speed, TypeScript provides strong typing and advanced features, and SWC handles rapid transpilation. Notably, the typescript package is not a dependency—SWC transpiles TypeScript independently, providing fast, lightweight builds.

In development mode, the server updates instantly to reflect changes in source files or tests. In production, it operates on optimized JavaScript for better performance.

This server template can be an ideal foundation for developing serverless functions, which are advantageous in modern cloud-native applications. Serverless functions, running in cloud environments, allow developers to focus on writing code without managing infrastructure. These functions respond to events such as HTTP requests or database changes and automatically scale with demand.

Scripts

Install

Installs the project dependencies.

pnpm i

Dev

Runs the server in development mode, with hot reloading to reflect changes made to the source files and tests.

pnpm dev

Test

Runs the Jest test suite using SWC for fast TypeScript transpilation.

pnpm test

Build

Transpiles the TypeScript source files to JavaScript using SWC. The output is saved in the dist directory.

pnpm build

Start

Runs the transpiled JavaScript code from the dist directory.

pnpm start

Dependencies

Main Dependencies

  • fastify: A fast and low-overhead web framework for Node.js, built for efficiency and scalability.

Development Dependencies

  • @swc-node/jest: A Jest transformer using SWC for efficient testing with TypeScript.
  • @swc-node/register: Allows on-the-fly transpilation of TypeScript to JavaScript using SWC during development.
  • @swc/cli: The command-line interface for the SWC transpiler.
  • @swc/core: The core library for SWC, used for fast TypeScript and JavaScript transpilation.
  • @swc/helpers: Helper functions used by SWC to support advanced JavaScript features.
  • @types/jest: TypeScript definitions for Jest, ensuring strong typing in test files.
  • @types/node: TypeScript definitions for Node.js APIs.
  • jest: A comprehensive testing framework for JavaScript and TypeScript.
  • nodemon: Monitors for changes in the source and automatically restarts the server in development mode.
  • ts-node: A TypeScript execution environment for Node.js, used here for interpreting the TypeScript Jest configuration file.

Serverless Functions Support (Fastify AWS Lambda)

This project is compatible with AWS Lambda through the @fastify/aws-lambda package, allowing you to build Fastify applications that can be deployed as serverless functions.

Installation

Before setting up your AWS Lambda integration, install the necessary package using:

pnpm i @fastify/aws-lambda

Key Benefits:

  • Fast Execution: Fastify's inject function and @fastify/aws-lambda's optimizations result in quicker performance.
  • Modular Architecture: Easily build and extend Fastify applications as serverless functions.
  • Seamless Integration: Fastify works smoothly with AWS Lambda and API Gateway, scaling automatically with demand.

Example Fastify AWS Lambda Setup

To set up a Fastify app for AWS Lambda, modify your src/index.ts and create a Lambda handler file (lambda.ts).

  1. Fastify App (src/index.ts):

    import fastify, { FastifyReply, FastifyRequest } from "fastify";
    
    const app = fastify();
    
    app.get("/", async (request: FastifyRequest, reply: FastifyReply) => {
      return { hello: "world" };
    });
    
    // ES Module alternative to require.main === module
    if (import.meta.url === `file://${process.argv[1]}`) {
      app.listen({ port: 3000 }, (err) => {
        if (err) {
          console.error(err);
          process.exit(1);
        }
        console.log("Server listening on port 3000");
      });
    }
    
    export default app; // Export the Fastify app for AWS Lambda
  2. Lambda Handler (lambda.ts):

    import awsLambdaFastify from "@fastify/aws-lambda";
    import app from "./src/index.js";
    
    const proxy = awsLambdaFastify(app);
    
    export const handler = proxy;
  3. Deploy: Deploy your Fastify app using AWS Lambda via a service such as Serverless Framework, AWS SAM, or AWS CDK.

Using Lambda Arguments in Fastify

Fastify passes the original Lambda event and context in requests by default. Access them like this:

app.get("/", (request: FastifyRequest, reply: FastifyReply) => {
  const event = request.awsLambda.event;
  const context = request.awsLambda.context;
  reply.send({ event, context });
});

Optimizing Cold Starts (In lambda.ts)

To lower cold start latency with AWS Lambda and Node.js 14+, you can use top-level await in combination with fastify.ready():

import awsLambdaFastify from "@fastify/aws-lambda";
import app from "./src/index.js";

export const handler = awsLambdaFastify(app);
await app.ready(); // Optimize cold starts
logo

Licensing

This project is licensed under the MIT License.

Third-Party Licenses

The repository uses some third-party dependencies under other licenses:

  • Apache-2.0
  • ISC

The full texts of these licenses are included in the repository.

Contributions and Issues

Contributions are welcome! If you have ideas or improvements, please open an issue first for discussion before submitting a pull request.
You can report issues or start discussions here: Open an issue

About

Fastify server leveraging swc-node for transpilation and Jest for testing

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published