-
Notifications
You must be signed in to change notification settings - Fork 0
Home
PSharp batch testing is an Addon for PSharp language.
PSharp batch tester uses Azure Batch Service to run multiple PSharp tests in parallel on the cloud and fetch the result. Using this tool you can run heavy testing in the cloud.
To run Psharp batch test, you need an Azure subscription and an Azure batch service account. To learn more about creating an Azure batch service account, view the sub-heading Azure Batch Service. Once you have that, follow the steps below:
-
Open the solution containing the PSharp project you need to test.
-
Install the Microsoft.PSharp.BatchTesting nuget from here: Microsoft.PSharp.Nuget.
-
Installing the Nuget will add two config files to the project.
- PSharpBatch.config : Contains configuration for uploading necessary files, testing in the cloud and downloading the results.
- PSharpBatchAuth.config : authentication credentials for Azure batch account and storage account.
(For more details about configuration go to: Configuring Batch Test).
-
Edit the configuration files to need and Open Nuget Package Manager Console.
-
Run the command BatchTest in Nuget Package Manager Console to start the Batch Testing.
PSharpBatch.config has the following parameters:
- PoolId : Id of the virtual machine pool in Azure batch service. If it doesn't exists already, it will be created.
- NumberOfNodesInPool : Number of VMs to be added in the pool, if it is created.
- NodeOsFamily : The OS version of the VMs. Should contain .Net Framework 4.6 and above (OsFamily: >=5). For more details visit Azure Guest OS Update Matix.
- JobDefaultId : Prefix for the Job to be created for the given tests. This will be appended by time-stamp.
- TaskDefaultId : Prefix for the tasks created under the Job. Will be appended by JobId and time-stamp.
- BlobContainerSasExpiryHours : Exipry time in hours for the files uploaded to storage account. After this time period, the Batch service will not be able to use the files. -1 for no expiry.
- PSharpBinariesFolderPath : Path to folder containing PSharp Binaries.
- OutputFolderPath : Path to folder where the output should be downloaded.
- TaskWaitHours : Waiting time in hours for the test to complete. Post this time, the unfinished tasks will be terminated.
- DeleteJobAfterDone : (true/false) Whether to delete the Batch-service job after it is complete.
- DeleteContainerAfterDone : (true/false) Whether to delete the storage account containers after the tests are complete.
-
Commands : PSharp test commands to run in cloud. You cna specify multiple commands via <command> tag.
- NumberOfParallelTasks : Number of parallel tasks to run. Equivalent to /parallel: flag in PSharp test command.
- IterationsPerTask : Number of iterations per task. Equivalent to /i: flag in PSharp test command.
- TestApplicaionPath : Path to the application to be tested (.dll/.exe).
- CommandFlags : Other flags to mention in the PSharp test command.
- CommandName : A name to command to distinguish between different tasks.
- SchedulingStratergy : Scheduling stratergy to run the test. Equivalent to /sch: flag in Psharp test command.
PSharpBatchAuth.config has the following parameters:
- BatchAccountName : Name of the Azure Batch Service Account.
- BatchAccountKey : Account Key for the Azure Batch Service Account.
- BatchAccountUrl : URL of the Azure Batch Service Account.
- StorageAccountName : Name of the Storage Account linked with the Azure Batch Service Account.
- StorageAccountKey : Account Key (Primary/Secondary) of the above mentioned Storage Account.
To configure Azure Batch service you need an active Azure subscription.
- Open the azure portal, and click New button.
- In the search bar search for Batch Service, and select the Batch Service option from the result.
- Click create and enter the required details. Also in this step create a new Storage Account and associate with the Batch Service before clicking create.
- After deployment is complete, you can go to the Batch account.
- The overview will give you the URL and the name of the account (Which you entered when creating the account).
- Go to the Keys tab and copy the Primary access key.
- You will need to Enter the account name, URL and the access key in PSharpBatchAuth.config.
- You can manually create the Pool from Azure Portal, or create using the PSharp Batch tester tool.