From 872c6c497954a0a677dc05cf370d8462f9f89539 Mon Sep 17 00:00:00 2001 From: arkpar Date: Wed, 15 Apr 2015 13:38:53 +0200 Subject: [PATCH] skip web preview for contracts which are not deployed yet --- HttpServer.cpp | 3 +++ qml/WebPreview.qml | 13 ++++++++----- test/qml/TestMain.qml | 9 +++++++++ test/qml/js/TestDebugger.js | 9 +++------ test/qml/js/TestProject.js | 3 +-- 5 files changed, 24 insertions(+), 13 deletions(-) diff --git a/HttpServer.cpp b/HttpServer.cpp index 977008e..9685809 100644 --- a/HttpServer.cpp +++ b/HttpServer.cpp @@ -110,7 +110,10 @@ void HttpServer::updateListening() return; if (!QTcpServer::listen(QHostAddress::LocalHost, m_port)) + { errorStringChanged(); + return; + } if (m_port != QTcpServer::serverPort()) { diff --git a/qml/WebPreview.qml b/qml/WebPreview.qml index bd1d37e..44f96a7 100644 --- a/qml/WebPreview.qml +++ b/qml/WebPreview.qml @@ -40,11 +40,14 @@ Item { var contracts = {}; for (var c in codeModel.contracts) { var contract = codeModel.contracts[c]; - contracts[c] = { - name: contract.contract.name, - address: clientModel.contractAddresses[contract.contract.name], - interface: JSON.parse(contract.contractInterface), - }; + var address = clientModel.contractAddresses[contract.contract.name]; + if (address) { + contracts[c] = { + name: contract.contract.name, + address: address, + interface: JSON.parse(contract.contractInterface), + }; + } } webView.runJavaScript("updateContracts(" + JSON.stringify(contracts) + ")"); } diff --git a/test/qml/TestMain.qml b/test/qml/TestMain.qml index ef1af0c..73cff82 100644 --- a/test/qml/TestMain.qml +++ b/test/qml/TestMain.qml @@ -50,12 +50,21 @@ TestCase function editContract(c) { + if (mainApplication.codeModel.compiling) + ts.waitForSignal(mainApplication.codeModel, "compilationComplete()", 5000); mainApplication.mainContent.codeEditor.getEditor("contract.sol").setText(c); if (!ts.waitForSignal(mainApplication.codeModel, "compilationComplete()", 5000)) fail("not compiled"); ts.keyPressChar(mainApplication, "S", Qt.ControlModifier, 200); //Ctrl+S } + + function waitForExecution() + { + while (mainApplication.clientModel.running) + ts.waitForSignal(mainApplication.clientModel, "runComplete()", 5000); + } + function editHtml(c) { mainApplication.projectModel.openDocument("index.html"); diff --git a/test/qml/js/TestDebugger.js b/test/qml/js/TestDebugger.js index b5b923f..706601d 100644 --- a/test/qml/js/TestDebugger.js +++ b/test/qml/js/TestDebugger.js @@ -14,8 +14,7 @@ function test_defaultTransactionSequence() " uint z;\r" + "}\r" ); - if (!ts.waitForSignal(mainApplication.clientModel, "runComplete()", 5000)) - fail("Error running transaction"); + waitForExecution(); tryCompare(mainApplication.mainContent.rightPane.transactionLog.transactionModel, "count", 3); } @@ -47,8 +46,7 @@ function test_transactionWithParameter() transactionDialog.acceptAndClose(); mainApplication.projectModel.stateDialog.acceptAndClose(); mainApplication.mainContent.startQuickDebugging(); - if (!ts.waitForSignal(mainApplication.clientModel, "runComplete()", 5000)) - fail("Error running transaction"); + waitForExecution(); tryCompare(mainApplication.mainContent.rightPane.transactionLog.transactionModel, "count", 5); tryCompare(mainApplication.mainContent.rightPane.transactionLog.transactionModel.get(4), "returned", "(442)"); } @@ -79,8 +77,7 @@ function test_constructorParameters() transactionDialog.acceptAndClose(); mainApplication.projectModel.stateDialog.acceptAndClose(); mainApplication.mainContent.startQuickDebugging(); - if (!ts.waitForSignal(mainApplication.clientModel, "runComplete()", 5000)) - fail("Error running transaction"); + waitForExecution(); tryCompare(mainApplication.mainContent.rightPane.transactionLog.transactionModel, "count", 4); tryCompare(mainApplication.mainContent.rightPane.transactionLog.transactionModel.get(3), "returned", "(442)"); } diff --git a/test/qml/js/TestProject.js b/test/qml/js/TestProject.js index 7f149ef..444760e 100644 --- a/test/qml/js/TestProject.js +++ b/test/qml/js/TestProject.js @@ -4,8 +4,7 @@ function test_contractRename() tryCompare(mainApplication.mainContent.projectNavigator.sections.itemAt(0).model.get(0), "name", "Contract"); editContract("contract Renamed {}"); mainApplication.mainContent.startQuickDebugging(); - if (!ts.waitForSignal(mainApplication.clientModel, "runComplete()", 5000)) - fail("Error running transaction"); + waitForExecution(); wait(1000); tryCompare(mainApplication.mainContent.projectNavigator.sections.itemAt(0).model.get(0), "name", "Renamed"); mainApplication.projectModel.stateListModel.editState(0);