Monocle is a Cross-Platform PowerShell Web Automation module, made to make automating and testing websites easier. It's a PowerShell wrapper around Selenium, with the aim of abstracting Selenium away from the user.
Monocle currently supports the following browsers:
- IE (v3.150.1.2)
- Chrome (v85.0.4183.8300)
- Firefox (driver: v0.27.0)
- Edge (driver: v81.0.416.77)
- EdgeLegacy (driver: v17.17134)
Install-Module -Name Monocle
Import-Module Monocle
# create a browser
$browser = New-MonocleBrowser -Type Chrome
# Monocle runs commands in web flows, for easy disposal and test tracking
Start-MonocleFlow -Name 'Load YouTube' -Browser $browser -ScriptBlock {
# tell the browser which URL to navigate to, will wait for the page to load
Set-MonocleUrl -Url 'https://www.youtube.com'
# sets the element's value, selecting the element by ID/Name
Get-MonocleElement -Id 'search_query' | Set-MonocleElementValue -Value 'Beerus Madness (Extended)'
# click the search button
Get-MonocleElement -Id 'search-icon-legacy' | Invoke-MonocleElementClick
# wait for the URL to change to start with the following value
Wait-MonocleUrl -Url 'https://www.youtube.com/results?search_query=' -StartsWith
# downloads an image from the page, selcted by using an XPath to an element
Get-MonocleElement -XPath "//div[@data-context-item-id='SI6Yyr-iI6M']/img[1]" | Save-MonocleImage -FilePath '.\beerus.jpg'
# tells the browser to click the video in the results
Get-MonocleElement -XPath "//a[@title='Dragon Ball Super Soundtrack - Beerus Madness (Extended)']" | Invoke-MonocleElementClick
# wait for the URL to be loaded
Wait-MonocleUrl -Url 'https://www.youtube.com/watch?v=SI6Yyr-iI6M'
}
# dispose the browser
Close-MonocleBrowser -Browser $browser
The following is a list of available functions in Monocle:
- Add-MonocleElementClass
- Assert-MonocleBodyValue
- Assert-MonocleElementValue
- Clear-MonocleElementValue
- Close-MonocleBrowser
- Edit-MonocleUrl
- Enter-MonocleFrame
- Get-Monocle2FACode
- Get-MonocleElement
- Get-MonocleElementAttribute
- Get-MonocleElementChild
- Get-MonocleElementCSS
- Get-MonocleElementParent
- Get-MonocleElementSibling
- Get-MonocleElementValue
- Get-MonocleHtml
- Get-MonoclePageSize
- Get-MonocleTimeout
- Get-MonocleUrl
- Install-MonocleDriver
- Invoke-MonocleElementCheck
- Invoke-MonocleElementClick
- Invoke-MonocleJavaScript
- Invoke-MonocleRetryScript
- Invoke-MonocleScreenshot
- Measure-MonocleElement
- Measure-MonocleElementChild
- Move-MonoclePage
- New-MonocleBrowser
- Remove-MonocleElementClass
- Remove-MonocleElementCSS
- Restart-MonocleBrowser
- Save-MonocleImage
- Set-MonocleElementAttribute
- Set-MonocleElementCSS
- Set-MonocleElementValue
- Set-MonocleTimeout
- Set-MonocleUrl
- Start-MonocleFlow
- Start-MonocleSleep
- Submit-MonocleForm
- Test-MonocleElement
- Test-MonocleElementAttribute
- Test-MonocleElementChecked
- Test-MonocleElementChild
- Test-MonocleElementClass
- Test-MonocleElementCSS
- Test-MonocleElementVisible
- Wait-MonocleElement
- Wait-MonocleElementVisible
- Wait-MonocleUrl
- Wait-MonocleUrlDifferent
- Wait-MonocleValue
If you need to use an earlier/later version of a driver, you manually download the driver and then supply a -Path
to New-MonocleBrowser
which is the directory that contains the driver.
New-MonocleBrowser -Type Chrome -Path 'C:\Drivers\Chrome\70.0.3156.0'
Also, you could use Install-MonocleDriver
. This will download a driver for you, and be automatically used by Monocle. This does require the nuget
CLI being installed.
There are two main ways to take a screenshot of the browser. The first it to tell Monocle to automatically take a screenshot whenever a flow fails. You can do this by using the -ScreenshotPath
and -ScreenshotOnFail
parameters on the Start-MonocleFlow
function:
Start-MonocleFlow -Name '<name>' -Browser $browser -ScriptBlock {
# failing logic
} -ScreenshotPath './path' -ScreenshotOnFail
Or, you can take a screenshot directly:
Invoke-MonocleScreenshot -Name 'screenshot.png' -Path './path'
Not supplying
-ScreenshotPath
or-Path
will default to the current path.
Monocle has inbuilt support for generating 2FA codes. To do this you need the Secret Code that is normally presented with the QR code, and you pass this to the Get-Monocle2FACode
function with a date - which is defaulted to now:
$code = Get-Monocle2FACode -Secret 'FAKENDMYJWLLB'
Get-MonocleElement -Id '2fa-code' | Set-MonocleElementValue -Value $code -Mask
Monocle has an official Docker image, which comes preloaded with:
- Monocle (obviously!)
- Firefox
- Google Chrome
You can use this image to run your Monocle flows - and they will also automatically run headless.
An example Dockerfile
could be:
FROM badgerati/monocle:latest
COPY . /usr/src/scripts
CMD [ "pwsh", "-c", "cd /usr/src/scripts; ./flow.ps1" ]
The you can build and run the image as follows:
docker build -t monocle/test .
docker run --rm monocle/test