Functions/New-PuppeteerCodeGenerator.ps1

<#
.SYNOPSIS
    This class generates snippets of Puppeteer code for UI automation.
#>

class PuppeteerCodeGenerator {

    ###########
    # Members #
    ###########
    # This is the folder where the screenshots will be stored, relative to the Node package directory.
    [String]$ScreenshotsFolder = "screenshots"

    # This selects if screenshots should be taken.
    [Bool]$ScreenshotsEnabled = $false

    # This tracks the current screenshot index.
    [Int32]$ScreenshotIndex = 0

    #################
    # Basic Methods #
    #################
    # This is the constructor for the code generator.
    PuppeteerCodeGenerator() {}

    # This method returns the code for calling a function.
    [String]CallFunction([String]$functionName) {
        return Get-Puppeteer_CallFunction -FunctionName $functionName
    }

    # This method returns the code for clicking on a selector and waiting for the page to load.
    [String]ClickOnSelector([String]$selectorName) {
        return $this.ClickOnSelector($selectorName, "wait")
    }

    # This method returns the code for clicking on a selector and choosing whether to wait
    # for the page to load.
    [String]ClickOnSelector([String]$selectorName, [String]$waitPolicy) {
        return Get-Puppeteer_ClickOnSelector -SelectorName $selectorName -WaitForPageToLoad:($waitPolicy -eq "wait")
    }

    # This method returns the code for closing the chrome browser.
    [String]CloseChromeBrowser() {
        return Get-Puppeteer_CloseChromeBrowser
    }

    # This method returns the code for closing a function declaration.
    [String]CloseFunctionDeclaration() {
        return Get-Puppeteer_CloseFunctionDeclaration
    }

    # This method returns the code for declaring the delay function.
    [String]DeclareDelayFunction() {
        return Get-Puppeteer_DeclareDelayFunction
    }

    # This method returns the code for declaring username and password variables.
    [String]DeclareUsernameAndPassword([PSCredential]$credential) {
        return Get-Puppeteer_DeclareUsernameAndPassword -Credential $credential
    }

    # This method returns the code for declaring a non-const variable.
    [String]DeclareVariable([String]$name, [String]$value) {
        return $this.DeclareVariable($name, $value, "nonConst")
    }

    # This method returns the code for declaring a variable, choosing if it is const or non-const.
    [String]DeclareVariable([String]$name, [String]$value, [String]$constPolicy) {
        return Get-Puppeteer_DeclareVariable -Name $name -Value $value -Const:($constPolicy -eq "const")
    }

    # This method returns the code for delaying for a specified number of seconds.
    [String]DelaySeconds([Int32]$seconds) {
        return $this.DelayMilliseconds($seconds * 1000)
    }

    # This method returns the code for delaying for a specified number of milliseconds.
    [String]DelayMilliseconds([Int32]$milliseconds) {
        return Get-Puppeteer_Delay -Milliseconds $milliseconds
    }

    # This method returns the code for entering text into a selector.
    [String]EnterTextIntoSelector([String]$selectorName, [String]$text) {
        return Get-Puppeteer_EnterTextIntoSelector -SelectorName $selectorName -Text $text
    }

    # This method returns the code for entering the value of a variable into a selector.
    [String]EnterVariableIntoSelector([String]$selectorName, [String]$variableName) {
        return Get-Puppeteer_EnterVariableIntoSelector -SelectorName $selectorName -VariableName $variableName
    }

    # This method returns the code for importing the Puppeteer requirements.
    [String]ImportRequirements() {
        return Get-Puppeteer_ImportRequirements
    }

    # This method returns the code for launching a chrome browser
    [String]LaunchChromeBrowser() {
        return Get-Puppeteer_LaunchChromeBrowser
    }

    # This method returns the code for logging a message.
    [String]LogMessage([String]$message) {
        return Get-Puppeteer_LogMessage -Message $message
    }

    # This method returns the code for logging the current url.
    [String]LogUrl() {
        return Get-Puppeteer_LogUrl
    }

    # This method returns the code for logging the value of a variable.
    [String]LogVariable([String]$variableName) {
        return Get-Puppeteer_LogVariable -VariableName $variableName
    }

    # This method returns the code for navigating a new browser page to a link.
    [String]NavigateNewBrowserPageToLink([String]$link) {
        return Get-Puppeteer_NavigateNewBrowserPageToLink -Link $link
    }

    # This method returns the code for opening an async function declaration.
    [String]OpenAsyncFunctionDeclaration([String]$functionName) {
        return Get-Puppeteer_OpenAsyncFunctionDeclaration -FunctionName $functionName
    }

    # This method returns the code for retrieving text from a selector.
    [String]RetrieveTextFromSelector([String]$selectorName, [String]$variableName) {
        return Get-Puppeteer_RetrieveTextFromSelector -SelectorName $selectorName -VariableName $variableName
    }

    # This method returns the code for setting the chrome browser options.
    [String]SetChromeBrowserOptions([String]$headlessPolicy, [Int32]$width, [Int32]$height) {
        return Get-Puppeteer_SetChromeBrowserOptions -IsHeadless ($headlessPolicy -eq "headless") -Width $width -Height $height
    }

    # This method returns the code for taking a screenshot.
    [String]TakeScreenshot([String]$filePath) {
        return Get-Puppeteer_TakeScreenshot -FilePath $filePath
    }

    # This method returns the code for throwing an exception upon encountering an unhandled rejection.
    [String]ThrowExceptionOnUnhandledRejection() {
        return Get-Puppeteer_ThrowExceptionOnUnhandledRejection
    }

    ####################
    # Compound Methods #
    ####################
    # This method returns the code for:
    # Writing a log message
    # Taking a screen shot using the processed log message as the file name
    [String]LogMessageWithScreenshot([String]$message) {
        # Generate the code
        $code = $this.LogMessage($message)

        # Add the screenshot code
        if ($this.ScreenshotsEnabled) {
            # Replace spaces with '_', remove non alphanumeric characters from the message
            # and trim to 100 characters
            $processedMessage = (($message -replace " ", "_") -replace "[^\w]*", "")
            if ($processedMessage.Length -gt 100) {
                $processedMessage = $processedMessage.Substring(0, 100)
            }

            # Generate the screenshot index string - format the index to be 3 characters wide
            $screenshotIndexString = $this.ScreenshotIndex.ToString("000")
            $this.ScreenshotIndex += 1

            # Set the screenshot file path
            if (![String]::IsNullOrWhiteSpace($this.ScreenshotsFolder)) {
                $screenshotFilePath = "$($this.ScreenshotsFolder)/$($screenshotIndexString)-$($processedMessage).jpeg"
            }
            else {
                $screenshotFilePath = "$($screenshotIndexString)-$($processedMessage).jpeg"
            }

            # Add to the code
            $code += "`r`n"
            $code += $this.TakeScreenshot($screenshotFilePath)
        }

        # Return the code
        return $code
    }
}

<#
.SYNOPSIS
    This function returns a new Puppeteer code generator object.
#>

function New-PuppeteerCodeGenerator {
    [CmdletBinding(PositionalBinding=$true)]
    [OutputType([PuppeteerCodeGenerator])]
    param ()
    return [PuppeteerCodeGenerator]::new()
}