| /* |
| * Copyright 2000-2009 JetBrains s.r.o. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package com.intellij.execution.testframework.sm.runner.ui.statistics; |
| |
| import com.intellij.execution.testframework.sm.runner.SMTestProxy; |
| import com.intellij.execution.testframework.sm.UITestUtil; |
| import com.intellij.ui.SimpleTextAttributes; |
| import com.intellij.util.ui.ColumnInfo; |
| import org.jetbrains.annotations.NotNull; |
| |
| /** |
| * @author Roman Chernyatchik |
| */ |
| public class ColumnDurationTest extends BaseColumnRenderingTest { |
| |
| public void testValueOf_NotRun() { |
| assertEquals("<NOT RUN>", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_InProgress() { |
| mySimpleTest.setStarted(); |
| assertEquals("<RUNNING>", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_TestFailure() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_TestPassed() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setFinished(); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_TestError() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", true); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_TestTerminated() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTerminated(); |
| assertEquals("<TERMINATED>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(10000); |
| assertEquals("TERMINATED: " + String.valueOf((float)10) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_TestIgnored() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestIgnored("todo", null); |
| mySimpleTest.setFinished(); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_Zero() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(0); |
| assertEquals("0 s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_1() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(1); |
| assertEquals("1 ms", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_99() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(99); |
| assertEquals("99 ms", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_100() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(100); |
| assertEquals(String.valueOf((float)0.1) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_999() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(999); |
| assertEquals(String.valueOf((float)0.999) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_1000() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(1000); |
| assertEquals(String.valueOf((float)1) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_Duration_1001() { |
| mySimpleTest.setStarted(); |
| mySimpleTest.setTestFailed("", "", false); |
| assertEquals("<UNKNOWN>", myColumn.valueOf(mySimpleTest)); |
| |
| mySimpleTest.setDuration(1001); |
| assertEquals(String.valueOf((float)1.001) + " s", myColumn.valueOf(mySimpleTest)); |
| } |
| |
| public void testValueOf_SuiteEmpty() { |
| final SMTestProxy suite = createSuiteProxy(); |
| suite.setStarted(); |
| suite.setFinished(); |
| assertEquals("<NO TESTS>", myColumn.valueOf(suite)); |
| |
| suite.setFinished(); |
| assertEquals("<NO TESTS>", myColumn.valueOf(suite)); |
| } |
| |
| public void testValueOf_SuiteNotRun() { |
| final SMTestProxy suite = createSuiteProxy(); |
| assertEquals("<NOT RUN>", myColumn.valueOf(suite)); |
| |
| final SMTestProxy test = createTestProxy("test", suite); |
| assertEquals("<NOT RUN>", myColumn.valueOf(suite)); |
| |
| test.setDuration(5); |
| assertEquals("<NOT RUN>", myColumn.valueOf(suite)); |
| } |
| |
| public void testValueOf_SuiteFailed() { |
| final SMTestProxy suite = createSuiteProxy(); |
| final SMTestProxy test = createTestProxy("test", suite); |
| |
| suite.setStarted(); |
| test.setTestFailed("", "", false); |
| suite.setFinished(); |
| |
| assertEquals("<UNKNOWN>", myColumn.valueOf(suite)); |
| |
| test.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(suite)); |
| } |
| |
| public void testValueOf_SuiteError() { |
| final SMTestProxy suite = createSuiteProxy(); |
| final SMTestProxy test = createTestProxy("test", suite); |
| |
| suite.setStarted(); |
| test.setTestFailed("", "", true); |
| suite.setFinished(); |
| |
| assertEquals("<UNKNOWN>", myColumn.valueOf(suite)); |
| |
| test.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(suite)); |
| } |
| |
| public void testValueOf_SuitePassed() { |
| final SMTestProxy suite = createSuiteProxy(); |
| final SMTestProxy test = createTestProxy("test", suite); |
| |
| suite.setStarted(); |
| test.setFinished(); |
| suite.setFinished(); |
| |
| assertEquals("<UNKNOWN>", myColumn.valueOf(suite)); |
| |
| test.setDuration(10000); |
| assertEquals(String.valueOf((float)10) + " s", myColumn.valueOf(suite)); |
| } |
| |
| public void testValueOf_SuiteTerminated() { |
| final SMTestProxy suite = createSuiteProxy(); |
| final SMTestProxy test = createTestProxy("test", suite); |
| |
| suite.setStarted(); |
| suite.setTerminated(); |
| |
| assertEquals("<TERMINATED>", myColumn.valueOf(suite)); |
| |
| test.setDuration(10000); |
| assertEquals("TERMINATED: " + String.valueOf((float)10) + " s", myColumn.valueOf(suite)); |
| } |
| |
| public void testValueOf_SuiteRunning() { |
| final SMTestProxy suite = createSuiteProxy(); |
| final SMTestProxy test = createTestProxy("test", suite); |
| |
| suite.setStarted(); |
| test.setStarted(); |
| |
| assertEquals("<RUNNING>", myColumn.valueOf(suite)); |
| |
| test.setDuration(10000); |
| assertEquals("RUNNING: " + String.valueOf((float)10) + " s", myColumn.valueOf(suite)); |
| } |
| |
| public void testTotal_Test() { |
| mySuite.addChild(mySimpleTest); |
| |
| doRender(mySimpleTest, 0); |
| assertFragmentsSize(1); |
| assertEquals(SimpleTextAttributes.REGULAR_ATTRIBUTES, myFragmentsContainer.getAttribsAt(0)); |
| assertEquals(myColumn.valueOf(mySimpleTest), myFragmentsContainer.getTextAt(0)); |
| |
| myFragmentsContainer.clear(); |
| doRender(mySimpleTest, 1); |
| assertFragmentsSize(1); |
| assertEquals(SimpleTextAttributes.REGULAR_ATTRIBUTES, myFragmentsContainer.getAttribsAt(0)); |
| assertEquals(myColumn.valueOf(mySimpleTest), myFragmentsContainer.getTextAt(0)); |
| } |
| |
| public void testTotal_RegularSuite() { |
| doRender(mySuite, 1); |
| assertFragmentsSize(1); |
| assertEquals(SimpleTextAttributes.REGULAR_ATTRIBUTES, myFragmentsContainer.getAttribsAt(0)); |
| assertEquals(myColumn.valueOf(mySuite), myFragmentsContainer.getTextAt(0)); |
| } |
| |
| public void testTotal_TotalSuite() { |
| doRender(mySuite, 0); |
| assertFragmentsSize(1); |
| assertEquals(SimpleTextAttributes.REGULAR_ATTRIBUTES, myFragmentsContainer.getAttribsAt(0)); |
| assertEquals(myColumn.valueOf(mySuite), myFragmentsContainer.getTextAt(0)); |
| } |
| |
| @Override |
| protected ColoredRenderer createRenderer(final SMTestProxy testProxy, |
| final UITestUtil.FragmentsContainer fragmentsContainer) { |
| return new MyRenderer(testProxy, fragmentsContainer); |
| } |
| |
| @Override |
| protected ColumnInfo<SMTestProxy, String> createColumn() { |
| return new ColumnDuration(); |
| } |
| |
| private class MyRenderer extends ColumnDuration.DurationCellRenderer { |
| private final UITestUtil.FragmentsContainer myFragmentsContainer; |
| |
| public MyRenderer(final SMTestProxy proxy, |
| final UITestUtil.FragmentsContainer fragmentsContainer) { |
| super(); |
| myFragmentsContainer = fragmentsContainer; |
| } |
| |
| @Override |
| public void append(@NotNull final String fragment, @NotNull final SimpleTextAttributes attributes, |
| final boolean isMainText) { |
| myFragmentsContainer.append(fragment, attributes); |
| } |
| } |
| } |