--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tsrc/testing/tools/wshTestRun_local.vbs Mon Jan 18 20:21:12 2010 +0200
@@ -0,0 +1,129 @@
+'
+' WScript that will invoke the test run execute functionality at ATS3 web server without installing any ATS3
+' specific programs on the local PC.
+'
+' Copies the test run zip into ATS3 server over HTTP before starting the test run
+'
+' Usage cscript wshRunX.vbs <username> <password> <server hostname> <path to testDrop.zip>
+'
+
+' Get the command line arguments
+set args = WScript.Arguments
+
+' Check that all arguments have been specified
+Set objShell = WScript.CreateObject("WScript.Shell")
+Set env = objShell.Environment("Process")
+checkEnvVars(env)
+
+' Invoke the web application and write the result to stdOut
+WScript.StdOut.Write doTestRunX(env("ats3.username"), env("ats3.password"), env("ats3.host"), env("ats3.pathToDrop"), URLEncode( env("ats3.schedule") ))
+
+' Quit the script
+Wscript.Quit
+
+Function checkEnvVars(env)
+ if env("ats3.username") = "" then
+ WScript.Echo "Environment variable ats3.username not specified"
+ WScript.Quit 1
+ elseif env("ats3.password") = "" then
+ WScript.Echo "Environment variable ats3.password not specified"
+ WScript.Quit 1
+ elseif env("ats3.host") = "" then
+ WScript.Echo "Environment variable ats3.host not specified"
+ WScript.Quit 1
+ elseif env("ats3.pathToDrop") = "" then
+ WScript.Echo "Environment variable ats3.pathToDrop not specified"
+ WScript.Quit 1
+ end if
+End Function
+
+' Invoke the ATS3 web application in given host with the specified username, password and file path
+Function doTestRunX(uname, password, hostName, pathToDrop, schedule)
+ Set objxmlHTTP = CreateObject("MSXML2.ServerXMLHTTP.3.0")
+ objxmlHTTP.setTimeouts 0,60000,3600000,3600000
+
+ Call objxmlHTTP.open("POST", "http://" & hostName & "/ats3/XTestRunExecute.do?username=" & uname & "&password=" & password & "&schedule=" & schedule, False)
+ objxmlHTTP.setRequestHeader "Content-Type", "multipart/form-data; boundary=AaB03x"
+
+ Set BinaryStream = CreateObject("ADODB.Stream")
+ BinaryStream.Type = 1
+ BinaryStream.Open
+ BinaryStream.LoadFromFile pathToDrop
+
+ objxmlHTTP.Send BuildFormData(BinaryStream.Read,"AaB03x","testDrop.zip","testDrop")
+
+ doTestRunX = objxmlHTTP.ResponseText
+
+ BinaryStream.Close
+End Function
+
+Function BuildFormData(FileContents, Boundary, FileName, FieldName)
+ Dim FormData, Pre, Po
+ Const ContentType = "application/upload"
+
+ 'The two parts around file contents In the multipart-form data.
+ Pre = "--" + Boundary + vbCrLf + mpFields(FieldName, FileName, ContentType)
+ Po = vbCrLf + "--" + Boundary + "--" + vbCrLf
+
+ 'Build form data using recordset binary field
+ Const adLongVarBinary = 205
+ Dim RS: Set RS = CreateObject("ADODB.Recordset")
+ RS.Fields.Append "b", adLongVarBinary, Len(Pre) + LenB(FileContents) + Len(Po)
+ RS.Open
+ RS.AddNew
+ Dim LenData
+ 'Convert Pre string value To a binary data
+ LenData = Len(Pre)
+ RS("b").AppendChunk (StringToMB(Pre) & ChrB(0))
+ Pre = RS("b").GetChunk(LenData)
+ RS("b") = ""
+
+ 'Convert Po string value To a binary data
+ LenData = Len(Po)
+ RS("b").AppendChunk (StringToMB(Po) & ChrB(0))
+ Po = RS("b").GetChunk(LenData)
+ RS("b") = ""
+
+ 'Join Pre + FileContents + Po binary data
+ RS("b").AppendChunk (Pre)
+ RS("b").AppendChunk (FileContents)
+ RS("b").AppendChunk (Po)
+ RS.Update
+ FormData = RS("b")
+ RS.Close
+ BuildFormData = FormData
+End Function
+
+Function mpFields(FieldName, FileName, ContentType)
+ Dim MPTemplate 'template For multipart header
+ MPTemplate = "Content-Disposition: form-data; name=""{field}"";" + _
+ " filename=""{file}""" + vbCrLf + _
+ "Content-Type: {ct}" + vbCrLf + vbCrLf
+ Dim Out
+ Out = Replace(MPTemplate, "{field}", FieldName)
+ Out = Replace(Out, "{file}", FileName)
+ mpFields = Replace(Out, "{ct}", ContentType)
+End Function
+
+Function StringToMB(S)
+ Dim I, B
+ For I = 1 To Len(S)
+ B = B & ChrB(Asc(Mid(S, I, 1)))
+ Next
+ StringToMB = B
+End Function
+
+Function URLEncode(data)
+ data = replace(data,"\","/")
+ data = replace(data,"$","%24")
+ data = replace(data,"&","%26")
+ data = replace(data,"+","%2B")
+ data = replace(data,",","%2C")
+ data = replace(data,"/","%2F")
+ data = replace(data,":","%3A")
+ data = replace(data,";","%3B")
+ data = replace(data,"=","%3D")
+ data = replace(data,"?","%3F")
+ data = replace(data,"@","%40")
+ URLEncode = data
+End Function
\ No newline at end of file