1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
# Copyright (C) 2016 The Qt Company Ltd.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
source("../../shared/qtcreator.py")
cloneUrl = "https://code.qt.io/installer-framework/installer-framework.git"
cloneDir = "myCloneOfIfw"
def verifyCloneLog(targetDir, canceled):
if canceled:
summary = "Failed."
else:
finish = findObject(":Git Repository Clone.Finish_QPushButton")
waitFor("finish.enabled", 90000)
cloneLog = str(waitForObject(":Git Repository Clone.logPlainTextEdit_QPlainTextEdit").plainText)
if "fatal: " in cloneLog:
test.warning("Cloning failed outside Creator.")
return False
# test for QTCREATORBUG-10112
test.compare(cloneLog.count("remote: Total"), 1)
test.compare(cloneLog.count("Receiving objects:"), 1)
test.compare(cloneLog.count("Resolving deltas:"), 1)
test.verify(not "Stopping..." in cloneLog,
"Searching for 'Stopping...' in clone log")
test.verify(("'" + cloneDir + "'..." in cloneLog),
"Searching for clone directory in clone log")
summary = "Succeeded."
try:
resultLabel = findObject(":Git Repository Clone.Result._QLabel")
test.verify(waitFor('str(resultLabel.text) == summary', 3000),
"Verifying expected result (%s)" % summary)
except:
if canceled:
test.warning("Could not find resultLabel",
"Cloning might have failed before clicking 'Cancel'")
return object.exists(":New_ProjectExplorer::JsonWizard")
else:
test.fail("Could not find resultLabel")
return True
def verifyVersionControlView(targetDir, canceled):
openVcsLog()
vcsLog = str(waitForObject("{type='Core::OutputWindow' unnamed='1' visible='1' "
"window=':Qt Creator_Core::Internal::MainWindow'}").plainText)
test.log("Clone log is: %s" % vcsLog)
test.verify("Running in " + targetDir + ":" in vcsLog,
"Searching for target directory in clone log")
test.verify(" ".join(["clone", "--progress", cloneUrl, cloneDir]) in vcsLog,
"Searching for git parameters in clone log")
test.compare(canceled, " terminated abnormally" in vcsLog,
"Searching for result in clone log")
clickButton(waitForObject(":*Qt Creator.Clear_QToolButton"))
def verifyFiles(targetDir):
for file in [".gitignore", "LICENSE.GPL3-EXCEPT", "installerfw.pro",
os.path.join("tests", "test-installer", "create-test-installer.bat"),
os.path.join("src", "sdk", "main.cpp")]:
test.verify(os.path.exists(os.path.join(targetDir, cloneDir, file)),
"Verify the existence of %s" % file)
def closeProposalPopup():
page = waitForObject(":JsonWizard_ProjectExplorer::JsonFieldPage")
checkbox = waitForObjectExists(":Recursive_QCheckBox")
mouseClick(page, page.width / 2, (page.height + checkbox.y + checkbox.height) / 2,
0, Qt.LeftButton)
def main():
startQC()
if not startedWithoutPluginError():
return
for button in ["Cancel immediately",
":Git Repository Clone.Cancel_QPushButton",
":Git Repository Clone.Finish_QPushButton"]:
__createProjectOrFileSelectType__(" Import Project", "Git Clone")
replaceEditorContent(waitForObject("{name='Repo' type='QLineEdit' visible='1'}"),
cloneUrl)
closeProposalPopup()
targetDir = tempDir()
replaceEditorContent(waitForObject(":Working Copy_Utils::BaseValidatingLineEdit"),
targetDir)
cloneDirEdit = waitForObject("{name='Dir' type='QLineEdit' visible='1'}")
test.compare(cloneDirEdit.text, "installer-framework")
replaceEditorContent(cloneDirEdit, cloneDir)
clickButton(waitForObject(":Next_QPushButton"))
cloneLog = waitForObject(":Git Repository Clone.logPlainTextEdit_QPlainTextEdit", 1000)
test.compare(waitForObject(":Git Repository Clone.Result._QLabel").text,
"Running Git clone...")
if button == "Cancel immediately":
# wait for cloning to have started
waitFor('len(str(cloneLog.plainText)) > 20 + len(cloneDir)')
clickButton(":Git Repository Clone.Cancel_QPushButton")
if not verifyCloneLog(targetDir, True):
continue
clickButton(":Git Repository Clone.Cancel_QPushButton")
else:
if not verifyCloneLog(targetDir, False):
clickButton(":Git Repository Clone.Cancel_QPushButton")
continue
verifyFiles(targetDir)
try:
clickButton(waitForObject(button))
except:
cloneLog = waitForObject(":Git Repository Clone.logPlainTextEdit_QPlainTextEdit")
test.fatal("Cloning failed",
str(cloneLog.plainText))
clickButton(":Git Repository Clone.Cancel_QPushButton")
continue
if button == ":Git Repository Clone.Finish_QPushButton":
try:
# Projects mode shown
clickButton(waitForObject(":Qt Creator.Configure Project_QPushButton", 5000))
test.passes("The checked out project was being opened.")
except:
clickButton(waitForObject(":Cannot Open Project.Show Details..._QPushButton"))
test.fail("The checked out project was not being opened.",
str(waitForObject(":Cannot Open Project_QTextEdit").plainText))
clickButton(waitForObject(":Cannot Open Project.OK_QPushButton"))
verifyVersionControlView(targetDir, button == "Cancel immediately")
invokeMenuItem("File", "Exit")
|