NOTICE: The TGIMBA git hub repository has been corrupted and I had to start over. The link to the repository is here -> Git Code Commit
Welcome back! In this post, I am continuing with setting up a .NET Core Angular 4 The Globe In My BucketList Application (TGIMBA) Continuous Integration Continuous Deployment (CICD) pipeline using Visual Studio Team Services (VSTS).
To recap, in the last post I was able to correct a .NET Core Test issue as well as completely run the mostly out of the box pipeline I got using the pipeline wizard. This would normally have been all I needed, but since this is an Angular 4 project, I need the node_modules directory as part of the deploy artifact. Despite my best efforts, I was not able to this using the MSBuild component supplied with the out of the box pipeline.
Given I had seen this issue with my local .bat file build script, I decided to start over and build it along similar lines. I was inspired to this approach after reading a post by the author of reference #3.
- Create Team Project
- Authorize connection to your GIT repository
- Select branch
- Nuget Restore – Installer (I am assuming this is needed since I had to install nuget on my local box when I did the .bat file build script)
- Nuget Restore
- Clean .NET Core solution
- Build .NET Core solution
- Run .NET Core tests
- NPM install of node_modules
- Build deploy artifact
Here is the key for me. In the previous pipeline, the build was created as a .zip file. Despite my best efforts, I never was able to get the node_modules (which were available) inserted into this .zip file. So, I uploaded the FolderProfile.pubxml used in my local .bat file (updated with appropriate relative paths) to my GIT hub repository and referenced it in the build step. There is probably a better way to do this, but this worked, so I decided to move on 🙂
Incorporated into the build step:
- Copy node_modules to build directory
- Publish build artifact to .zip file that can be downloaded
All together, the pipeline looks like this:
The files generated look like this (my coveted node_modules is present 🙂 )
Next, I will figure out how to deploy to my production site using File Transfer Protocol (FTP).