Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/siberex/bazel-nestjs-starter

Example of Bazel build config for NestJS app
https://github.com/siberex/bazel-nestjs-starter

bazel build docker js nest nestjs nodejs rules-nodejs ts typescript

Last synced: 3 months ago
JSON representation

Example of Bazel build config for NestJS app

Awesome Lists containing this project

README

        

![Bazel at Scalio](https://raw.githubusercontent.com/scalio/bazel/master/assets/scalio-bn.svg?sanitize=true)

Bazel Nest Starter


A starter app written in Typescript for NestJS -- built using Bazel

 
## Overview

This project was created by invoking the default Nest app scaffold via the Nest CLI, and then the addition of simple `BUILD.bazel` and `WORKSPACE` files, making use of [rules_nodejs](https://github.com/bazelbuild/rules_nodejs/#quickstart).

To create this from scratch in a new project, run the following:

```bash
nest new AppName
yarn create @bazel APP_NAME --packageManager=yarn --typescript
```

and now add the files `WORKSPACE` and `src/BUILD.bazel` to your new directory root and `src` folders, respectively.

## Build and run

With Bazel installed:

```bash
bazel run //src:server
```

Without Bazel installed:

```bash
yarn install -D
yarn bazel:run
```

## Docker

Build Docker image:

```bash
bazel build --platforms=@build_bazel_rules_nodejs//toolchains/node:linux_amd64 //src:docker
```

Push image to the registry (currently set to `gcr.io`):

```bash
bazel run --define push_tag=${IMAGE_TAG} --define push_repository=${REPOSITORY} //src:push_container
```

## Credits

Created by [@siberex](https://github.com/siberex/) @ [Scalio](https://scal.io/)

## About us