Implement CICD Pipeline for Uipath Project Using Azure DevOps Pipelines

  1. Create a new project from the studio or use an existing project from any version control. In my case, I am using GitHub.
  2. In my project, I have one “main.xaml“ file along with two test cases.

image

  1. If you are creating a new project from the studio. Kindly please connect the project to the version control and push the code to it.

image

  1. After performing the above steps. My project is connected to Github.
    Let’s start the configuration in Azure DevOps.
  2. Kindly create an account at https://dev.azure.com/.
  3. Once the account is ready. The home page looks like below.

Prerequisites
• Enable the “Uipath integration” extension.
• Npm should be installed.
• Activate the agent.
Enable the “UiPath Integration” extension
• Click on “Organization settings” on the Azure DevOps home screen.
image

• Click on the “Extensions” options from the left side of the menu.
image

• Click on “Browse Market Place” from the right side of the panel.
image

• Search with the “UiPath” keyword you will get two products UiPath integration, UiPath test manager
• Install “UiPath integration extension”.
• After installation, you can able to see “UiPath integration extension” in installed tabs.

image

Npm installation
• Kindly download the latest version of the node setup based on your operating system.
• After the installation. Kindly verify whether npm is installed or not by using the following command.

image

• If it displays the version number your installation is successful.

Activate the agent
• Click on “Organization settings” on the Azure DevOps home screen.
image

• Click on “Agent pools” from the left-hand side menu.
image

• It will show two options on the right side “Azure Pipelines”,” Default”.
• Kindly select the Default option.
• Click on the “New Agent” button
image

• Another window will pop up. Kindly please select the respective operating system.
• Download the agent by clicking on the download button.
• Perform the steps as mentioned in the popup.

image

• After performing the above steps. It will ask a set of questions.
• Server url: https://dev.azure.com/XXXXXXXXXX(Example)
• Enter authentication type (press enter for PAT) → Get PAT from Azure DevOps home screen → Click on user settings icons → click on option “Personal access token”.
• Click on create a new token option-> Provide some name to and choose full access as the scope-> Hit on create button.
• Make note of the PAT key.
• Kindly provide PAT key in the power shell and hit enter.

image

• We are creating an agent in the default pool. So, No need to provide any name just hit enter.
• It will ask “Agent name”. Just hit enter. So, It will create an agent name with your system name.
• It will ask “Work folder” path. I am hitting enter. So, the project files will save in “C:\agent_work” by default.
• Choose “n” for the next two.
• Kindly execute the “.\run” command
• Finally, your agent is ready to execute the jobs and pipelines. To verify whether the agent is online or offline. Kindly please navigate to agent pools → Default. There you can see the status of your agent.

  1. Click on the new project button. Kindly please provide the azure project name and choose either private or public. In my scenario, I have chosen public.
  2. You can see projects in the projects tab.

  1. Click on the newly created project. In my scenario, I am clicking “Azure_CICD_Example”.

  2. Once you navigated to the newly created project. We have to configure the orchestrator connection with Azure DevOps.

  3. You can find the “Project Settings” option at the bottom left
    image

  4. Click on “Project settings” → “Service Connections” → “New service connection” → Type “Uipath” → Select “Uipath Orchestrator Connection”.

  5. Click on “Next”.

  6. You can see 3 options to configure orchestrator connection.” Basic Authentication”, “Token-based Authentication”, “ External Application”.

  7. In my scenario, I have chosen “Token-based Authentication”.

  8. To get that information. Kindly open “community version orchestrator” → Click on “More” → select “Admin” → Select “Tenants” option-> Choose which tenant you should have to create a project → Expand the tenant. In my scenario, my tenant name is “Expleo Solutions” → Select more options at orchestrator → Click on “API Access”.

image

  1. A window gets pop up. It has all the information regarding token-based authentication.

image

  1. Orchestrator URL, Account logical name, API key(User Key),Tenant(Tenant name), Service connection name(You can provide any name ).
  2. Select the “Grant access permission to all pipelines” checkbox.
  3. Once you have done. It will show as below. In my scenario, I have given the service connection name “UiPath_Testing”.

image

  1. Click on the new pipeline → Select GitHub option.

image

  1. Kindly please provide your GitHub credentials to access GitHub and select the project which you have pushed.
  2. Select Starter.yaml option.
  3. It will automatically create a Yaml file.
  4. In that kindly change pool to default. Because our agent is located at “Default”.

image

  1. Next, let’s add the UiPath Pack task to the YAML file. To do that, click on Show assistant and search for UiPath Pack. Choose your personal preference for the Versioning Method and Trace Level. Then, select the Service Connection in the Orchestrator Connection dropdown. Under Project(s) Path, type $(Build.SourcesDirectory). Finally, under Output Path, type $(Build.ArtifactStagingDirectory)\Output

  1. Next, let’s add the UiPath. Test task to execute an existing test set in Orchestrator. Similar to adding UiPath Pack task, you can search for the UiPath Test task in Show Assistant. There are two test execution methods. The Execute test set method will run a preexisting test set in Orchestrator, while the Execute tests in project method will run tests in the transient project. If you select the Execute test set method, you need to create a test set in Orchestrator first, then provide the test set name in the Test set field.

  2. In my scenario, we will choose the Execute tests in project method. Specify your service connection and Orchestrator folder, then click on Add.

  3. Finally, search for Publish Build Artifact task in Show Assistant, give the Artifact a name, then click on Add. Congrats, you completed the build pipeline for your automation project. Proceed with saving the YAML file. You can run the pipeline to verify the result.

image

Step 7: Create a Release pipeline

Finally, you will learn how to create a release pipeline for your automation process. At this stage, your automation process will be deployed to a production environment. First, go to the Releases tab under the Pipeline section and select New pipeline. It will ask you to select a template. You can close it for now.

Click on the Add an artifact block, select the Source Type as Build, choose the project and the build pipeline that we configured in the previous step, and click Add.



Then, move on to the Stages block and click on Add a Stage → select Empty job → click on 1 job, 0 task link.


You will see Agent job under the Tasks tab. Click on it to open the Agent job page. On the Agent job page, under the Demands section, add “npm”. Next, click on the “+” icon next to Agent job to add a new task to the agent job.


Search for “UiPath Deploy” here, add it, and configure the Orchestrator connection, Orchestrator folder. Click on “…” to browse the package path and point it to the Output directory of your folder. Click on Save.


Then, go to the Pipeline tab, click on the lightning icon under Artifacts, and enable the Continuous Deployment trigger and save it again. This meant that whenever a build was created a release pipeline would be triggered. After that, click on Save to save all changes.

Finally, click on the Create Release button right next to the Save button. Select the stage you just created in the previous steps, and click Create.

image

Congratulations! You have both the build pipeline and release pipeline built now. To test whether the pipeline works, you can commit a code change in your automation process.
Then, you should be able to see the build pipeline is triggered, which will pack the automation process into a NuGet package and execute the test cases in Orchestrator. After the build pipeline runs successfully, the release pipeline will be triggered spontaneously to deploy the automation process to the destined folder in Orchestrator.

13 Likes

This is very informative. But may I know if we can use windows agents provided by azurePipeline without installing a local agent ?

Yes, we can. For that you need to use “vm-image: windows agent” instead of pool in yaml file.

1 Like

I’m seeing the following error when using cloud Orchestrator service connection:

*Could not connect to Cloud Orchestrator, Refresh Token: ***, Tenant: ***, Account Name: **, OrganizationUnit: My Workspace.

Please make sure that the provided URL (UiPath) is correct, available from your build agent, and not blocked by a firewall.

I’ve implemented this previously for on-prem, however can’t seem to get it to work for cloud, using either External Application or token-based authentication. Same error each time.

Thanks for sharing

Can you share me cloud orchestrator url with me? Make sure you should have to provide https://cloud.uipath.com.

Thanks for your comments Nitya

If you still facing issue. We will connect I will share you a demo how it will work.

Hi,

Do you know how to get the same logs of Orchestartor jobs on Azure devops pipeline.

When we are trying to run the UiPath jobs from Azure devops pipeline, it shows only jobs failed or passed, no other logs,

@sachinbhardwaj We don’t have any specific task to get logs in the DevOps. But you can achieve writing a script by calling OData API

1 Like

If I wanted to have custom versioning, like semantic versioning, how would I do that?


Can you suggest me a workaround to resolve this issue i see in azure devops release pipeline?
Appreciate all your inputs and suggestions!!

@eliamma.joseph Could you please share the complete log message screenshot?
As per the error message, kindly please check whether you have installed the desktop runtime 6.0.20 in the agent machine or not.


https://docs.uipath.com/test-suite/automation-suite/2023.4/user-guide/uipath-command-line-interface#prerequisites

1 Like

Thanks for your quick reply. Have attached the screenshot of the logs

Kindly please install .Net 6.0.7 before deploy task. @eliamma.joseph

2 Likes

Hi, without any doubt it’s an amazing and helpful post for all. I am successfully done with this but following issue is happening for 2nd run(when any changes will come to my git)

  1. After changes any of the code and do “commit and push” again from studio then it will lost all azure-pipelines.yml from github and yaml from azure(it will be blank).


    after that need to create again pipeline from azure.

  2. If I will do the commit only from studio(after changes of the code). The pipeline will not run automatically from azure (automatic trigger on). If I will run it manually then it will throw an error
    like “2023-12-12T11:30:28.7404743Z ##[error]Error deploying package: Error: The process ‘C:\Program Files\dotnet\dotnet.exe’ failed with exit code 1.”

for the following scenarios what should i do? Any of the assistance would be helpful for me. Thanks in advance.

Hi @Poritos_Pal ,

Same happens for me as well when I try to push from studio.
My test and deploy pipelines are throwing errors,build was a success.
I have installed the packages as well.

2024-05-14T12:17:00.1719817Z at UiPath.CommandLine.Clients.OrchestratorClientFactory.<>c__DisplayClass5_0.<g__HandleBuild|8>d.MoveNext()
2024-05-14T12:17:00.7044847Z ##[error]Error deploying package: Error: The process ‘C:\Program Files\dotnet\dotnet.exe’ failed with exit code 1.
2024-05-14T12:17:00.7090422Z ##[section]Finishing: UiPathDeploy

Any workaround @BalaManikanta_007 , @Poritos_Pal

Regards,
Geetishree

I have this exact same issue, did you connect with him and fix the issue? What is the fix?

Hi, I had the same issue. It got fixed post adding below lines in yaml under steps:

- task: UseDotNet@2
    displayName: 'Use .NET Core sdk 6.0.302'
    inputs:
        version: 6.0.302

1 Like

Hi @Deeksha_Bhat ,

It is still failing at UiPath test after adding the above.
Can’t find loc string for key: AccountNameForApp

Could we connect to discuss more on this.

Thanks and Regards,
Geetishree