Script manager changes
This commit is contained in:
parent
f5597334db
commit
94bce0670c
4 changed files with 64 additions and 12 deletions
|
@ -1,4 +1,5 @@
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
using BankingBot.Attributes;
|
using BankingBot.Attributes;
|
||||||
using BankingBot.Contracts;
|
using BankingBot.Contracts;
|
||||||
|
@ -6,6 +7,7 @@ using BankingBot.LoginCredentials;
|
||||||
using OpenQA.Selenium;
|
using OpenQA.Selenium;
|
||||||
using BankingBot.Responses;
|
using BankingBot.Responses;
|
||||||
using BankingBot.Enums;
|
using BankingBot.Enums;
|
||||||
|
using BankingBot.ScriptManagement;
|
||||||
|
|
||||||
namespace BankingBot.ActionManagers.LoginManagers
|
namespace BankingBot.ActionManagers.LoginManagers
|
||||||
{
|
{
|
||||||
|
@ -20,10 +22,14 @@ namespace BankingBot.ActionManagers.LoginManagers
|
||||||
}
|
}
|
||||||
|
|
||||||
private readonly IBrowserBot _browserBot;
|
private readonly IBrowserBot _browserBot;
|
||||||
|
private readonly IScriptManager _scriptManager;
|
||||||
|
|
||||||
public LloydsLoginManager(IBrowserBot browserBot)
|
public LloydsLoginManager(
|
||||||
|
IBrowserBot browserBot,
|
||||||
|
IScriptManager scriptManager)
|
||||||
{
|
{
|
||||||
_browserBot = browserBot;
|
_browserBot = browserBot;
|
||||||
|
_scriptManager = scriptManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Response Login(ILoginCredentials credentials)
|
public Response Login(ILoginCredentials credentials)
|
||||||
|
@ -31,6 +37,16 @@ namespace BankingBot.ActionManagers.LoginManagers
|
||||||
var response = new Response();
|
var response = new Response();
|
||||||
var lloydsCreds = (LloydsLoginCredentials)credentials;
|
var lloydsCreds = (LloydsLoginCredentials)credentials;
|
||||||
|
|
||||||
|
var data = new Dictionary<string, string>
|
||||||
|
{
|
||||||
|
{ "name", "aaron" },
|
||||||
|
{ "age", "12" },
|
||||||
|
{ "isOldEnough", "true" }
|
||||||
|
};
|
||||||
|
|
||||||
|
_scriptManager.Execute("scripts/test.js", data, ScriptBundles.Global);
|
||||||
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
LoginStep1(lloydsCreds);
|
LoginStep1(lloydsCreds);
|
||||||
|
|
|
@ -58,6 +58,7 @@
|
||||||
<Compile Include="Contracts\ILoginManager.cs" />
|
<Compile Include="Contracts\ILoginManager.cs" />
|
||||||
<Compile Include="Contracts\IProviderLoginManager.cs" />
|
<Compile Include="Contracts\IProviderLoginManager.cs" />
|
||||||
<Compile Include="Contracts\IResponse.cs" />
|
<Compile Include="Contracts\IResponse.cs" />
|
||||||
|
<Compile Include="Contracts\IScriptManager.cs" />
|
||||||
<Compile Include="Enums\Provider.cs" />
|
<Compile Include="Enums\Provider.cs" />
|
||||||
<Compile Include="Enums\ResponseStatus.cs" />
|
<Compile Include="Enums\ResponseStatus.cs" />
|
||||||
<Compile Include="LoginCredentials\LloydsLoginCredentials.cs" />
|
<Compile Include="LoginCredentials\LloydsLoginCredentials.cs" />
|
||||||
|
@ -70,7 +71,6 @@
|
||||||
<Compile Include="Responses\Response.cs" />
|
<Compile Include="Responses\Response.cs" />
|
||||||
<Compile Include="ScriptManagement\ScriptBundles.cs" />
|
<Compile Include="ScriptManagement\ScriptBundles.cs" />
|
||||||
<Compile Include="ScriptManagement\ScriptManager.cs" />
|
<Compile Include="ScriptManagement\ScriptManager.cs" />
|
||||||
<Compile Include="ScriptManagement\Scripts.cs" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="packages.config" />
|
<None Include="packages.config" />
|
||||||
|
|
10
BankingBot/Contracts/IScriptManager.cs
Normal file
10
BankingBot/Contracts/IScriptManager.cs
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace BankingBot.Contracts
|
||||||
|
{
|
||||||
|
public interface IScriptManager
|
||||||
|
{
|
||||||
|
T Execute<T>(string scriptPath, Dictionary<string, string> data, string[] scripts);
|
||||||
|
void Execute(string scriptPath, Dictionary<string, string> data, string[] scripts);
|
||||||
|
}
|
||||||
|
}
|
|
@ -10,7 +10,7 @@ using OpenQA.Selenium.Internal;
|
||||||
|
|
||||||
namespace BankingBot.ScriptManagement
|
namespace BankingBot.ScriptManagement
|
||||||
{
|
{
|
||||||
public class ScriptManager
|
public class ScriptManager : IScriptManager
|
||||||
{
|
{
|
||||||
private readonly IBrowserBot _browserBot;
|
private readonly IBrowserBot _browserBot;
|
||||||
|
|
||||||
|
@ -21,31 +21,57 @@ namespace BankingBot.ScriptManagement
|
||||||
|
|
||||||
public T Execute<T>(string scriptPath, Dictionary<string, string> data = null, string[] includedScripts = null)
|
public T Execute<T>(string scriptPath, Dictionary<string, string> data = null, string[] includedScripts = null)
|
||||||
{
|
{
|
||||||
var scriptContent = "";
|
var script = GenerateScript(scriptPath, data, includedScripts);
|
||||||
|
var executor = _browserBot.WebDriver as IJavaScriptExecutor;
|
||||||
|
return (T)executor.ExecuteScript(script);
|
||||||
|
}
|
||||||
|
|
||||||
if (includedScripts != null)
|
public void Execute(string scriptPath, Dictionary<string, string> data, string[] includedScripts = null)
|
||||||
|
{
|
||||||
|
var script = GenerateScript(scriptPath, data, includedScripts);
|
||||||
|
var executor = _browserBot.WebDriver as IJavaScriptExecutor;
|
||||||
|
}
|
||||||
|
|
||||||
|
private string GetIncludedScriptsCompilation(string currentCompliation, string[] scripts)
|
||||||
|
{
|
||||||
|
if (scripts != null)
|
||||||
{
|
{
|
||||||
foreach (var script in includedScripts)
|
foreach (var script in scripts)
|
||||||
{
|
{
|
||||||
var includedScriptContent = File.ReadAllText(script).Trim();
|
currentCompliation += GetScriptContent(script);
|
||||||
scriptContent += includedScriptContent;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
scriptContent += File.ReadAllText(scriptPath).Trim();
|
return currentCompliation;
|
||||||
|
}
|
||||||
|
|
||||||
|
private string GetScriptContent(string scriptPath)
|
||||||
|
{
|
||||||
|
return File.ReadAllText(scriptPath).Trim();
|
||||||
|
}
|
||||||
|
|
||||||
|
private string GetScriptWithPopulatedData(string currentCompliation, Dictionary<string, string> data)
|
||||||
|
{
|
||||||
if (data != null)
|
if (data != null)
|
||||||
{
|
{
|
||||||
var placeholderFormat = "__${0}";
|
var placeholderFormat = "__${0}";
|
||||||
foreach (var pair in data)
|
foreach (var pair in data)
|
||||||
{
|
{
|
||||||
var placeholderText = string.Format(placeholderFormat, pair.Key);
|
var placeholderText = string.Format(placeholderFormat, pair.Key);
|
||||||
scriptContent = scriptContent.Replace(placeholderText, pair.Value);
|
currentCompliation = currentCompliation.Replace(placeholderText, pair.Value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var executor = _browserBot.WebDriver as IJavaScriptExecutor;
|
return currentCompliation;
|
||||||
return (T)executor.ExecuteScript(scriptContent);
|
}
|
||||||
|
|
||||||
|
private string GenerateScript(string scriptPath, Dictionary<string, string> data = null, string[] includedScripts = null)
|
||||||
|
{
|
||||||
|
var scriptContent = GetIncludedScriptsCompilation("", includedScripts);
|
||||||
|
scriptContent += GetScriptContent(scriptPath);
|
||||||
|
scriptContent = GetScriptWithPopulatedData(scriptContent, data);
|
||||||
|
|
||||||
|
return scriptContent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue