Create SAM pipeline
Preparation
In this step, we will create IAM roles for CodePipeline - Deploy stage and CodeBuild.
Warning
The role is configured with minimal security, suitable only for a workshop environment.
-
Create CodePipeline - Deploy stage role.
- Open AWS IAM console, then click Roles on the left menu.
- Click Create role button.
data:image/s3,"s3://crabby-images/77dcd/77dcd6fe87e972fb81382a8349b86073e4978414" alt="CreatePipeline"
- At Step 1: Select trusted entity page.
- Choose AWS service at Trusted entity type.
- Enter
CloudFormation
at Service or use case and choose CloudFormation at Use case.
- Then click Next button.
data:image/s3,"s3://crabby-images/d0733/d0733228fd767c827eaeb458ceea4bb342960459" alt="CreatePipeline"
- At Step 2: Add permissions page.
- Enter
AdministratorAccess
at Search box.
- Choose AdministratorAccess policy.
- Then click Next button.
data:image/s3,"s3://crabby-images/00b6a/00b6aacf42a8f186aa81e3ee16809990f9003ae7" alt="CreatePipeline"
- At Step 3: Name, review, and create page.
- Enter
fcjCodePipelineDeployStageRole
at Role name.
data:image/s3,"s3://crabby-images/0ed34/0ed34eae4d70d6a6c122925303d668b907006d9b" alt="CreatePipeline"
- Scroll down and click Create role button.
data:image/s3,"s3://crabby-images/16244/16244a10eaa4a9e7098d3ebb1eeb2ccf174ec226" alt="CreatePipeline"
-
Create CodeBuild role.
- Open AWS IAM console, then click Roles on the left menu.
- Click Create role button.
data:image/s3,"s3://crabby-images/77dcd/77dcd6fe87e972fb81382a8349b86073e4978414" alt="CreatePipeline"
- At Step 1: Select trusted entity page.
- Choose AWS service at Trusted entity type.
- Enter
CodeBuild
at Service or use case and choose CodeBuild at Use case.
- Then click Next button.
data:image/s3,"s3://crabby-images/583c9/583c91296a2dca2a88372dc563d675bb09d13ac5" alt="CreatePipeline"
- At Step 2: Add permissions page.
- Enter
AdministratorAccess
at Search box.
- Choose AdministratorAccess policy.
- Then click Next button.
data:image/s3,"s3://crabby-images/00b6a/00b6aacf42a8f186aa81e3ee16809990f9003ae7" alt="CreatePipeline"
- At Step 3: Name, review, and create page.
- Enter
fcjCodeBuildRole
at Role name.
data:image/s3,"s3://crabby-images/aa9c1/aa9c1145bffe12cd1bd8325618f72c0d73140021" alt="CreatePipeline"
- Scroll down and click Create role button.
data:image/s3,"s3://crabby-images/c81e1/c81e11db28656d70fb3f25251932a45a06eb70da" alt="CreatePipeline"
Create the pipeline
-
Open AWS CodePipeline console.
- Click Pipelines on the left menu.
- Click Create pipeline button.
data:image/s3,"s3://crabby-images/34c3a/34c3abc1d5b5e31f7648bdebee39d05379cb5f82" alt="CreatePipeline"
-
At Step 1: Choose creation option page.
- Choose Build custom pipeline at Creation options.
- Then click Next button.
data:image/s3,"s3://crabby-images/03106/03106b3cc1dff22b70f686c56525d41770b7937b" alt="CreatePipeline"
-
At Step 2: Choose pipeline settings page.
- Enter
fcjBookStorePipeline
at Pipeline name.
- Choose Queued at Execution mode.
- Choose New service role at Service role.
- Enter
AWSCodePipelineServiceRole-us-east-1-fcjBookStorePipeline
at Role name.
- Click the Next button.
data:image/s3,"s3://crabby-images/de6e5/de6e510a26492546a7e524f8d5f4c0f14bb6b4d3" alt="CreatePipeline"
-
At Step 3: Add source stage page.
- Choose Gitlab at Source provider.
- Click the Connect to Gitlab button.
data:image/s3,"s3://crabby-images/0135f/0135f77da4f12686f9d9716feb20dde1330b26a7" alt="CreatePipeline"
- At Create a connection page at new browser tab is just opened.
- Enter
fcjBookStoreGitlabConnection
at Connection name.
- Click the Connect to Gitlab button.
data:image/s3,"s3://crabby-images/1fdf1/1fdf19a0c1881c998a4bae355ed481c9f04cbb73" alt="CreatePipeline"
- After successful login to Gitlab, click the Connect button.
data:image/s3,"s3://crabby-images/58717/58717b37e532bd3a7a0d029883d50d6514e5b07f" alt="CreatePipeline"
- Check if the Gitlab connection is successful.
- Enter
fcj-ws/fcj-book-store-backend
at Repository name.
- Enter
master
at Default branch.
data:image/s3,"s3://crabby-images/75e85/75e85ef2198a11e32bbf3cafb0c7c18bac88f1dd" alt="CreatePipeline"
- Scroll down to the bottom and click the Next button.
data:image/s3,"s3://crabby-images/cd8c6/cd8c66f897d0acaa2765ca1c5a87e51ba230102f" alt="CreatePipeline"
-
At Step 4: Add build stage page.
- Choose Other build providers at Build provider.
- Choose the AWS CodeBuild.
- Click the Create project button.
data:image/s3,"s3://crabby-images/f17d1/f17d18143e6b9b97ade2401af211cddf18c60bf3" alt="CreatePipeline"
- At Create build project page at the new browser tab is just opened.
- Enter
fcjBookStoreBuildProject
at Project name.
data:image/s3,"s3://crabby-images/79d19/79d19c5dffeded3e97d4816b77e0ddc79e66bd7b" alt="CreatePipeline"
- Scroll down, choose Ubuntu at Operating system.
- Choose Existing service role at Service role.
- Choose fcjCodeBuildRole at Role ARN.
data:image/s3,"s3://crabby-images/7c32e/7c32e610641b4bbde230911c782902df4a396cc4" alt="CreatePipeline"
- Scroll down to the bottom, choose Use a buildspec file at Build specifications.
- Click the Continue to CodePipeline button.
data:image/s3,"s3://crabby-images/77e30/77e30880fc55ac20a671ee06e9f827f6c97e3eba" alt="CreatePipeline"
- Choose the fcjBookStoreBuildProject at Project name.
- Leave as default and click the Next button.
data:image/s3,"s3://crabby-images/db99f/db99fa414aac1cd8ef1d16ac1cf391c8a2327f77" alt="CreatePipeline"
-
At Step 5: Add test stage page.
- Click the Skip test stage button.
data:image/s3,"s3://crabby-images/bc40b/bc40b4a2901140f4eb82b6bf15e819832a614b9d" alt="CreatePipeline"
-
At Step 6: Add deploy stage page.
- Choose the AWS CloudFormation at Deploy provider.
- Choose the BuildArtifact at Input artifacts.
- Choose the Create or update a stack at Action mode.
- Enter
fcj-book-store
at Stack name.
data:image/s3,"s3://crabby-images/31a32/31a323207662dd7e96d26930fbf7a6b440c8524b" alt="CreatePipeline"
- Scroll down, choose BuildArtifact at Artifact name.
- Enter
packaged.yaml
at File name.
- Choose the CAPABILITY_IAM, CAPABILITY_NAMED_IAM and CAPABILITY_AUTO_EXPAND at Capabilities - optional.
- Choose the fcjCodePipelineDeployStageRole at Role name.
- Click the Next button.
data:image/s3,"s3://crabby-images/ec666/ec66675d87c352ba7d34d724526fe97b2be8951c" alt="CreatePipeline"
-
At Step 7: Review page.
- Scroll down and click the Create pipeline button.
data:image/s3,"s3://crabby-images/c049b/c049b5de5dd484ffea5cb7b40927095e653e0c49" alt="CreatePipeline"
Test the pipeline
-
Open AWS CodePipeline console.
- Click Pipelines on the left menu.
- Choose fcjBookStorePipeline pipeline.
data:image/s3,"s3://crabby-images/24483/2448368945a8618359f332c065a914fd981c6a19" alt="CreatePipeline"
-
At fcjBookStorePipeline page.
- Scroll down to the bottom, click the View details button.
data:image/s3,"s3://crabby-images/3fb28/3fb280dbbc61f34b72f14fca28325b045ea8a1e3" alt="CreatePipeline"
-
At fcjBookStorePipeline - Deploy stage page.
- Choose the Output tab and record the ApiUrl.
data:image/s3,"s3://crabby-images/42d20/42d202e5c4089f0b2f8899f57ada015b704dac3b" alt="CreatePipeline"