This top section of the README describes how to get started with the template and should be deleted after the template has been generated.
A solution template for quickly creating a microservice using the following technologies:
- NancyFx
- NServiceBus
- StructureMap
- NHibernate / Fluent NHibernate
- Crux
- FluentMigrator
- AutoMapper
- FluentValidation
- Refit
At Third Wave Technology, we use this template as a starting point when we create a new service layer application for our clients.
This template is designed to be used with WarmuP, a command-line utility that substitutes a single replacement token across file and folder names, as well as within the individual files within a Git repo or local directory.
To use WarmuP, you will need to install some prerequisites:
-
Ruby 2.1 or later
-
Install the WarmuP gem by running the following:
$ gem install warmup
-
Open a command prompt and
cd
into the directory where you want to create the new repository. -
Using an administrative command prompt, type the following:
$ warmup https://github.com/ThirdWaveTech/Microservice.Template <<Your Solution Name>>
For example, let's say you were creating a microservice to manage users. You might enter something like this:
$ warmup https://github.com/ThirdWaveTech/Microservice.Template MyCompany.UserService
$ cd MyCompany.UserService
The solution contains several projects. At first glance it might seem like a lot, but this is by design. While it's certainly possible to combine them into fewer more coarse-grained projects, we decided to keep them separate to emphasize the separation of concerns behind the architecture. This template is only a starting point so feel free to modify it as you see fit. :)
NOTE: The __NAME__ token will be replaced with your solution name by WarmuP.
A NancyFx application which provides an HTTP API to your clients. This app is where you will implement the synchronous communication to your service.
An NServiceBus host application. This app provides asynchronous, durable communication into your service.
This library is where you implement your domain logic using Domain Driven Design principles. Common implementations of the DDD patterns are provided by the Crux library.
This library is where you implement your NHibernate ORM mappings and configuration.
This library contains your FluentMigrator migrations. It also has some SQL scripts that can be used with Physique to create an efficient developer workflow.
A library that can be used by .NET clients to call your HTTP service. It uses Refit to create lightweight interfaces.
A library that can be used by .NET clients to call your service via message queueing.
A library containing the strongly-typed model objects used by the API.
A library containing the messages that will be consumed and published by the message bus.
The solution contiains three NUnit assemblies:
For unit tests, unsurprisingly.
For integration tests that talk to a database, an external API, or any other external component.
For acceptance tests that communicate with the service layer via it's public interface. These tests are not run when invoking the default test
task. Instead you run them via:
$ bundle exec rake acceptance
The rake
tasks provided by Physique allow you to easily create a continuous integration build on your favorite CI server. Simply configure the following task to be run on every commit. You can customize which tasks are run as part of the CI build in your Rakefile
.
$ bundle exec rake ci
The build scripts are also pre-configured to package and publish the applications to Octopus Deploy for deployment. You should never check in your API key, but instead specify it as an environment variable of your build server.
$ OCTOPUS_API_KEY=<<Your API Key>> bundle exec rake publish
If you are not using Octopus to deploy your apps, you can simply remove that configuration from your Rakefile
.
The template comes with an ExampleEntity domain entity which is manipulated by different parts of the service. This entity is provided for illustrative purposes only and you may delete it and any of its supporting classes at any time.
There is an issue in the database drop, create, and seed scripts when providing a dotted replacement token (i.e. "MyCompany.MyService"). SQLCMD.exe, which runs the scripts, doesn't like dotted parameters. If you use a dotted name, remember to remove the dots in the database name in the generated connection strings and Rakefile.
Feel free to contact me @scardetto if you have any questions.
If you are looking for professional consulting services to help you build your service layer, contact us for a free consultation.
- Fork it ( https://github.com/thirdwavetech/microservice.template/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
The following is the actual README that you should include in the solution generated by the template.
Describe this service.
- Ruby 2.1 or later.
- Microsoft SQL Server or SQL Server Express Edition.
- IIS (not Express)
This solution uses the Physique Ruby gem to build and deploy the solution. To build and run the tests included in the template, type the following:
$ gem install bundler # Install the required bundler gem.
$ bundle install # This will install the gems required for the build.
$ bundle exec rake test # This will build the solution and run all of the unit and integration tests.
To rebuild the database locally using the migrations, run the following from the command-prompt:
$ bundle exec db:rebuild
This solution uses Physique and FluentMigrator to create and run database migrations locally, on the continuous integration server and during deployments. The NAME.Database project contains the migrations which are used to build and share database changes across the team. For more information on how to use Physique and FluentMigrator, refer to this guide.
This solution also includes a suite of acceptance tests that perform black-box testing against the service interface.
However, before running the acceptance suite, we must first ensure that the IIS Application Pool's identity can access your local SQL server. By default, the app pools are configured to run as IIS APPPOOL\DefaultAppPool
. The following script will create a login for that user and grant them access to your local database.
$ bundle exec rake init_app_pool_login
With that out of the way, the easiest way to run the acceptance tests is to run the solution in the Visual Studio debugger and the type the following:
$ bundle exec rake acceptance
The solution comes with several other build tasks, to see the list of tasks available to you, type the following at the command-line:
$ bundle exec rake --tasks