What is servant build tool?

What is servant build tool?

Servant builder is simple build tool for developers, that wants to build and manage modularized large projects in monorepo or separated into more repositories. With this tool you will be able to control used libraries, build and rebuild all packages at all or only selected once, run tests in more browsers and device, validate all your code against eslint or prettier and finally publish your packages into repository. Servant basically try to learn the best way of managing and developing of multiple modules projects and its maintenance with grace. It's try to be simple but powerful tool and good servant :wink:

Key features

  • Monorepo manage and configuration Manage monorepo with one configuration file that can contains definition for your monorepo, directory structure, validator settings, publish settings and more! There will be only small config files in every module to customize names and overriding some specific settings.
  • Installing and update at once Make install and update npm commands at once for all defined modules or for some specific modules only.
  • Controlling and unifying dependencies versions Manage all dependencies, unify across all packages to be same in version. Servant will automatically warn you if there are some dependencies that are not same across all packages and provide same commands to unify this versions across all packages.
  • Testing on more browsers and devices Servant allows you to run tests against more than 70 devices in 3 different browsers. This all because Servant using playwright library to run tests in. But even if you are not want to use playwright, Servant try to run all tests in Chrome browsers. And that is possible only one simple configuration record in configuration file.
  • Validating quality of your code Check quality of your code by using eslint and prettier: servant can run validation of all supported validators in one step and report all errors and warnings on one place with nice command line results. These validators can be manage by using or not using config files related to supported validator and can be turned on only for some modules or for all.
  • Smart publishing into repository Servant can also provide publish of all your packages into repository. And because we need some kind of versioning manage, you are able to choose if Servant will increase packages patch, minor, major or any prerelease version and also commit some message about version increment into git. Servant can also fix packages versions or removing devDependencies during publishing.
  • Development server with "Servants link" For better developer experience, Servant has own dev server, that can provide automatically rebuilding on change. This server automatically includes all necessary libraries that are defined in dependencies and by default is include only libraries, that are compatible with browser. So you are able to check if your modules will be work as package in browser.

    Servant also come with feature called "Servants link". If there are more Servants run in watch mode, there are communicating each others. Servant detects others packages and can rebuild modules that are connected through dependencies. Let's look on some example. You have a company monorepo "main-app" with packages. Also, there is company repo "library-app". Some package from "main-app" has dependency to "library-app". Both repos use Servant as build tool. If you run "main-app" and "library-app" in watch mode, Servant run from "main-app" detect that there is a "library-app" Servant running and link this into "main-app". So now "main-app" use live build of library "library-app" and also, if you make some changes Servant first ensure rebuild of "library-app" and then "main-app". And that's all :) You never need to create some link and another hacks manually!

Caveats

Servant dev serves has no support for hot module replacement for now. This will be implemented in future releases so now you need make pages reload after rebuild of modules.

servant.example1.gif

Installation and start!

1. Globally installed

You need the latest version of nodejs and then run:

npm install @servant/servant-cli -g

Then you can run in current directory:

servant clean

Caveats

Installing globally is not recommended.

Servant will be complaining about missing package.json and servant.json. We will create it. Servant has special flag to init main project or submodule. We will create main project now with using --init flag and answer all questions that servant give us.

servant --init

After init project with calling "node_modules/.bin/servant" --init, Servant create package.jsonfile with script called "servant". Now you can use npm run servant to call servant from your current directory.

Caveats

If you want to pass arguments into Servant run through npm run you must separate arguments with --

For example: npm run servant -- clean build --production

2. Locally installed

You need the latest version of nodejs and then run:

npm install @servant/servant-cli

Then you can run in current directory:

"node_modules/.bin/servant" clean

Servant will be complaining about missing package.json and servant.json. We will create it. Servant has special flag to init main project or submodule. We will create main project now with using --init flag and answer all questions that servant give us.

node_modules/.bin/servant --init

After init project with calling "node_modules/.bin/servant" --init, Servant create package.json file with script called "servant". Now you can use npm run servant to call servant from your current directory.

Caveats

If you want to pass arguments into Servant run through npm run you must separate arguments with --

For example: npm run servant -- clean build --production

3. Installed and init with npx

You need the latest version of nodejs and then run

npx @servant/servant-cli --init

This command run init runtime of servant, that will create skeleton of first project. There is wizard that can help to create settings that you need and also prepare first files and make install of all dependencies.

servant.init.gif

Supported technologies

  • less (*.less ): You can use less in your module. Servant automatically build it and add to folder for distribution. Servant also make automatically conversion from .less to .d.ts typescript definition for usage in your project.

  • sass (*.scss): You can use sass in your module. Servant automatically build it and add to folder for distribution. Servant also make automatically conversion from .scss to .d.ts typescript definition for usage in your project.

  • css (*.css ): You can use css in your module. Servant automatically build it and add to folder for distribution. Servant also make automatically conversion from .css to .d.ts typescript definition for usage in your project.

  • typescript (*.ts , *.tsx ): Servant is use for Typescript and in current version it's on of two supported language. Use .ts files and Servant do the rest.

  • javascript (*.js, *.jsx): Servant is use for Javascript and in current version it's one of two supported language. Use .js files and Servant do the rest.

Used technologies

Servant used these technologies for building and creating the best developer experience for developing in supported technologies.

webpack: Webpack is used for building and bundling. Servant automatically generate config file for webpack so is not necessary to do something.

typed-css-modules: Module for building *.d.ts definitions from less, sass or css files.

eslint: Module for validating *.ts and *.js files.

prettier: Module for formatting lots of files that are supported by this tool.

Playground

You can use playground that is used for trying Servant in real project. Servant playground has it's own repo and can be accessed on link playground. More info is inside this repo!

Servant project structure

If you want to use Servant, you must create the right folder structure for right behaviour. Servant needs it and for working with it. This is the best approach to your project and for Servant of course.

 .
 ├── module.one              # Example module (folder)
 │   ├── package.json        # Package json for module one
 │   ├── servant.json        # Servant config file for module one
 │   ├── (tsconfig.json)     # OPTIONAL: Typescript config for module one
 │   ├── (.eslintrc.json)    # OPTIONAL: Eslint config for module one
 │   └── (.prettierrc.json)  # OPTIONAL: Prettier config for module one
 ├── ...
 ├── module.two              # Example module (folder)
 │   ├── package.json        # Package json for module two
 │   ├── servant.json        # Servant config file for module two
 │   ├── (tsconfig.json)     # OPTIONAL: Typescript config for module two
 │   ├── (.eslintrc.json)    # OPTIONAL: Eslint config for module two
 │   └── (.prettierrc.json)  # OPTIONAL: Prettier config for module two
 ├── ...
 ├── package.json            # Required file for dependencies resolving
 ├── (tsconfig.json)         # OPTIONAL: Only use it if you want to do typescript module
 ├── (.eslintrc.json)        # OPTIONAL: Root eslint config for all modules (can share default rules, ..)
 └── servant.json            # Main config file of servant

Config servant.json, NodeJS api, command line api

Servant use file servant.json as main configuration file for all Servant settings. This is description of servant.json on gitlab here or can continue to chapter What is servant.json file?

Servant can also be used from node js process. For this there is available simple Servant api that can provide all necessary information and can be used inside your integration module or another runtime. There will be also separate article abou using of Servant api.

But for all Servant is primary used for calling from command line. Can be used many ways with lot's of predefined commands and options. It's designed for fast creating and managing large projects composed from independent modules. Command line api is described in on gitlab and also there will be separate article about using command line.

Did you find this article valuable?

Support Stanislav Hacker by becoming a sponsor. Any amount is appreciated!