Angular CLI is a powerful tool to scaffold and build Angular apps. Not only it provides you scalable project structure, instead, it handles all common tedious tasks for you out of the box and it already follows the Angular best practices.
Build and test your application in a minute
As tasks, we’ve common commands like:
ng newto initialize a new Angular project with a lot of settings.
ng generateto generate something from a blueprint.
ng serveto build the application and starts a web server.
ng buildto compile the application into an output directory.
ng testto run your unit tests with Karma the provided test runner.
ng lintto lint you app code using tslint to ensure best practices of Angular.
With these commands, you can easily create a new Angular app, generate some components following blueprints and build it in few minutes. Even that, you can ensure everything is still functional with the test runner and if you still respect the style and best practices from Angular with the linter. And this, without any configuration necessary, everything is already ready so you can run test without any further configuration. However, these tools are only effective if you run the command, otherwise, it’s a wasted potential.
To use it at its full potential, we can automatically execute these commands into a continuous integration tool such as CircleCI, Travis, AppVeyor, Jenkins, Bamboo, and a lot more, hooked with your source control on each commit, pull request and even prevent merge if these commands fail. In that way, this will prevent someone from merging if his code doesn’t match with your or Angular style and breaking your project with unbuildable code. You’ve probably already heard “but it’s working on my computer“ that’s exactly what we want to prevent here.
All you have to do is to setup the environment and executes these previous pre-chewed commands.
First, let’s build our angular application in production and AoT to be sure everything is alright, then test it and finally lint it. It can be executed on multiple tools, but let’s do examples for a few, at least my favorites.
We will use Yarn as a fast and secure package manager to cache our dependencies between builds, for more information refer to this article:
Version 2.0 has been rolled out few days ago, enjoy this updated config.
For more information, feel free to checkout the repository that was used to experiment this :