Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'valgrind/org.eclipse.linuxtools.valgrind.massif.tests/src/org/eclipse/linuxtools/internal/valgrind/massif/tests/LaunchConfigTabTest.java')
-rw-r--r--valgrind/org.eclipse.linuxtools.valgrind.massif.tests/src/org/eclipse/linuxtools/internal/valgrind/massif/tests/LaunchConfigTabTest.java610
1 files changed, 305 insertions, 305 deletions
diff --git a/valgrind/org.eclipse.linuxtools.valgrind.massif.tests/src/org/eclipse/linuxtools/internal/valgrind/massif/tests/LaunchConfigTabTest.java b/valgrind/org.eclipse.linuxtools.valgrind.massif.tests/src/org/eclipse/linuxtools/internal/valgrind/massif/tests/LaunchConfigTabTest.java
index e9fe0e49f9..6a53b695b3 100644
--- a/valgrind/org.eclipse.linuxtools.valgrind.massif.tests/src/org/eclipse/linuxtools/internal/valgrind/massif/tests/LaunchConfigTabTest.java
+++ b/valgrind/org.eclipse.linuxtools.valgrind.massif.tests/src/org/eclipse/linuxtools/internal/valgrind/massif/tests/LaunchConfigTabTest.java
@@ -37,309 +37,309 @@ import org.junit.Test;
public class LaunchConfigTabTest extends AbstractMassifTest {
- private ValgrindOptionsTab tab;
- private MassifToolPage dynamicTab;
- private ILaunchConfiguration config;
- private Shell testShell;
-
- @Before
- public void prep() throws Exception {
- proj = createProjectAndBuild("alloctest"); //$NON-NLS-1$
-
- config = createConfiguration(proj.getProject());
-
- testShell = new Shell(Display.getDefault());
- testShell.setLayout(new GridLayout());
- tab = new ValgrindOptionsTab();
- }
-
- @Override
- @After
- public void tearDown() throws CoreException {
- tab.dispose();
- testShell.dispose();
- deleteProject(proj);
- super.tearDown();
- }
-
- private ILaunchConfigurationWorkingCopy initConfig() throws CoreException {
- ILaunchConfigurationWorkingCopy wc = config.getWorkingCopy();
- tab.setDefaults(wc);
- tab.createControl(testShell);
- tab.initializeFrom(config);
- int ix = Arrays.asList(tab.getTools()).indexOf(MassifPlugin.TOOL_ID);
- tab.getToolsCombo().select(ix);
- ILaunchConfigurationTab dynamicTab = tab.getDynamicTab();
- this.dynamicTab = (MassifToolPage) dynamicTab;
- return wc;
- }
-
- private ILaunch saveAndLaunch(ILaunchConfigurationWorkingCopy wc,
- String testName) throws URISyntaxException, IOException,
- CoreException {
- tab.performApply(wc);
- config = wc.doSave();
-
- ILaunch launch = doLaunch(config, testName);
- return launch;
- }
-
- @Test
- public void testDefaults() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- ILaunch launch = saveAndLaunch(wc, "testDefaults"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--tool=massif")); //$NON-NLS-1$
- assertFalse(cmd.contains("--xml=yes")); //$NON-NLS-1$
- assertTrue(cmd.contains("-q")); //$NON-NLS-1$
- assertTrue(cmd.contains("--trace-children=no")); //$NON-NLS-1$
- assertTrue(cmd.contains("--child-silent-after-fork=yes")); //$NON-NLS-1$
- assertTrue(cmd.contains("--demangle=yes")); //$NON-NLS-1$
- assertTrue(cmd.contains("--num-callers=12")); //$NON-NLS-1$
- assertTrue(cmd.contains("--error-limit=yes")); //$NON-NLS-1$
- assertTrue(cmd.contains("--show-below-main=no")); //$NON-NLS-1$
- assertFalse(cmd.contains("--suppressions")); //$NON-NLS-1$
- assertTrue(cmd.contains("--max-stackframe=2000000")); //$NON-NLS-1$
- assertTrue(cmd.contains("--run-libc-freeres=yes")); //$NON-NLS-1$
-
- assertTrue(cmd.contains("--heap=yes")); //$NON-NLS-1$
- assertTrue(cmd.contains("--heap-admin=8")); //$NON-NLS-1$
- assertTrue(cmd.contains("--stacks=no")); //$NON-NLS-1$
- assertFalse(cmd.contains("--alloc-fn")); //$NON-NLS-1$
- assertTrue(cmd.contains("--threshold=1.0")); //$NON-NLS-1$
- assertTrue(cmd.contains("--peak-inaccuracy=1.0")); //$NON-NLS-1$
- assertTrue(cmd.contains("--time-unit=i")); //$NON-NLS-1$
- assertTrue(cmd.contains("--detailed-freq=10")); //$NON-NLS-1$
- assertTrue(cmd.contains("--max-snapshots=100")); //$NON-NLS-1$
- assertFalse(cmd.contains("--alignment=")); //$NON-NLS-1$
- }
-
- @Test
- public void testHeap() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getHeapButton().setSelection(false);
- ILaunch launch = saveAndLaunch(wc, "testHeap"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--heap=no")); //$NON-NLS-1$
- }
-
- @Test
- public void testHeapAdmin() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getHeapAdminSpinner().setSelection(30);
- ILaunch launch = saveAndLaunch(wc, "testHeapAdmin"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--heap-admin=30")); //$NON-NLS-1$
- }
-
- @Test
- public void testStacks() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getStacksButton().setSelection(true);
- ILaunch launch = saveAndLaunch(wc, "testStacks"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--stacks=yes")); //$NON-NLS-1$
- }
-
- @Test
- public void testDepth() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getDepthSpinner().setSelection(50);
- ILaunch launch = saveAndLaunch(wc, "testDepth"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--depth=50")); //$NON-NLS-1$
- }
-
- @Test
- public void testAllocFn() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getAllocFnList().add("foo"); //$NON-NLS-1$
- ILaunch launch = saveAndLaunch(wc, "testAllocFn"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--alloc-fn=foo")); //$NON-NLS-1$
- }
-
- @Test
- public void testAllocFnMultiple() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getAllocFnList().add("foo"); //$NON-NLS-1$
- dynamicTab.getAllocFnList().add("bar"); //$NON-NLS-1$
- ILaunch launch = saveAndLaunch(wc, "testAllocFnMultiple"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--alloc-fn=foo")); //$NON-NLS-1$
- assertTrue(cmd.contains("--alloc-fn=bar")); //$NON-NLS-1$
- }
-
- @Test
- public void testAllocFnSpace() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getAllocFnList().add("operator new(unsigned)"); //$NON-NLS-1$
- ILaunch launch = saveAndLaunch(wc, "testAllocFnSpace"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--alloc-fn=operator new(unsigned)")); //$NON-NLS-1$
- }
-
- @Test
- public void testThreshold() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getThresholdSpinner().setSelection(20);
- ILaunch launch = saveAndLaunch(wc, "testThreshold"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--threshold=2.0")); //$NON-NLS-1$
- }
-
- @Test
- public void testPeakInaccuracy() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getPeakInaccuracySpinner().setSelection(0);
- ILaunch launch = saveAndLaunch(wc, "testPeakInaccuracy"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--peak-inaccuracy=0.0")); //$NON-NLS-1$
- }
-
- @Test
- public void testTimeUnitBytes() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- String[] items = dynamicTab.getTimeUnitCombo().getItems();
- int ix = -1;
- for (int i = 0; i < items.length; i++) {
- if (items[i].equals(MassifToolPage.TIME_B_STRING)) {
- ix = i;
- }
- }
- dynamicTab.getTimeUnitCombo().select(ix);
- ILaunch launch = saveAndLaunch(wc, "testTimeUnitBytes"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--time-unit=B")); //$NON-NLS-1$
- }
-
- @Test
- public void testTimeUnitMilliseconds() throws CoreException,
- URISyntaxException, IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- String[] items = dynamicTab.getTimeUnitCombo().getItems();
- int ix = -1;
- for (int i = 0; i < items.length; i++) {
- if (items[i].equals(MassifToolPage.TIME_MS_STRING)) {
- ix = i;
- }
- }
- dynamicTab.getTimeUnitCombo().select(ix);
- ILaunch launch = saveAndLaunch(wc, "testTimeUnitMilliseconds"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--time-unit=ms")); //$NON-NLS-1$
- }
-
- @Test
- public void testDetailedFreq() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getDetailedFreqSpinner().setSelection(1);
- ILaunch launch = saveAndLaunch(wc, "testDetailedFreq"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--detailed-freq=1")); //$NON-NLS-1$
- }
-
- @Test
- public void testMaxSnapshots() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
- dynamicTab.getMaxSnapshotsSpinner().setSelection(200);
- ILaunch launch = saveAndLaunch(wc, "testMaxSpapshots"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--max-snapshots=200")); //$NON-NLS-1$
- }
-
- @Test
- public void testAlignment() throws CoreException, URISyntaxException,
- IOException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
-
- assertFalse(dynamicTab.getAlignmentSpinner().getEnabled());
- dynamicTab.getAlignmentButton().setSelection(true);
- dynamicTab.getAlignmentButton().notifyListeners(SWT.Selection, null);
- assertTrue(dynamicTab.getAlignmentSpinner().getEnabled());
-
- dynamicTab.getAlignmentSpinner().setSelection(512);
- tab.performApply(wc);
- config = wc.doSave();
-
- assertTrue(tab.isValid(config));
-
- ILaunch launch = doLaunch(config, "testAlignment"); //$NON-NLS-1$
- IProcess[] p = launch.getProcesses();
- assertTrue("process array should not be empty", p.length > 0);
- String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
- assertEquals(0, p[0].getExitValue());
- assertTrue(cmd.contains("--alignment=512")); //$NON-NLS-1$
- }
-
- @Test
- public void testAlignmentBad() throws CoreException {
- ILaunchConfigurationWorkingCopy wc = initConfig();
-
- assertFalse(dynamicTab.getAlignmentSpinner().getEnabled());
- dynamicTab.getAlignmentButton().setSelection(true);
- dynamicTab.getAlignmentButton().notifyListeners(SWT.Selection, null);
- assertTrue(dynamicTab.getAlignmentSpinner().getEnabled());
-
- dynamicTab.getAlignmentSpinner().setSelection(63);
- tab.performApply(wc);
- config = wc.doSave();
-
- assertFalse(tab.isValid(config));
- }
+ private ValgrindOptionsTab tab;
+ private MassifToolPage dynamicTab;
+ private ILaunchConfiguration config;
+ private Shell testShell;
+
+ @Before
+ public void prep() throws Exception {
+ proj = createProjectAndBuild("alloctest"); //$NON-NLS-1$
+
+ config = createConfiguration(proj.getProject());
+
+ testShell = new Shell(Display.getDefault());
+ testShell.setLayout(new GridLayout());
+ tab = new ValgrindOptionsTab();
+ }
+
+ @Override
+ @After
+ public void tearDown() throws CoreException {
+ tab.dispose();
+ testShell.dispose();
+ deleteProject(proj);
+ super.tearDown();
+ }
+
+ private ILaunchConfigurationWorkingCopy initConfig() throws CoreException {
+ ILaunchConfigurationWorkingCopy wc = config.getWorkingCopy();
+ tab.setDefaults(wc);
+ tab.createControl(testShell);
+ tab.initializeFrom(config);
+ int ix = Arrays.asList(tab.getTools()).indexOf(MassifPlugin.TOOL_ID);
+ tab.getToolsCombo().select(ix);
+ ILaunchConfigurationTab dynamicTab = tab.getDynamicTab();
+ this.dynamicTab = (MassifToolPage) dynamicTab;
+ return wc;
+ }
+
+ private ILaunch saveAndLaunch(ILaunchConfigurationWorkingCopy wc,
+ String testName) throws URISyntaxException, IOException,
+ CoreException {
+ tab.performApply(wc);
+ config = wc.doSave();
+
+ ILaunch launch = doLaunch(config, testName);
+ return launch;
+ }
+
+ @Test
+ public void testDefaults() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ ILaunch launch = saveAndLaunch(wc, "testDefaults"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--tool=massif")); //$NON-NLS-1$
+ assertFalse(cmd.contains("--xml=yes")); //$NON-NLS-1$
+ assertTrue(cmd.contains("-q")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--trace-children=no")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--child-silent-after-fork=yes")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--demangle=yes")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--num-callers=12")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--error-limit=yes")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--show-below-main=no")); //$NON-NLS-1$
+ assertFalse(cmd.contains("--suppressions")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--max-stackframe=2000000")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--run-libc-freeres=yes")); //$NON-NLS-1$
+
+ assertTrue(cmd.contains("--heap=yes")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--heap-admin=8")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--stacks=no")); //$NON-NLS-1$
+ assertFalse(cmd.contains("--alloc-fn")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--threshold=1.0")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--peak-inaccuracy=1.0")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--time-unit=i")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--detailed-freq=10")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--max-snapshots=100")); //$NON-NLS-1$
+ assertFalse(cmd.contains("--alignment=")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testHeap() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getHeapButton().setSelection(false);
+ ILaunch launch = saveAndLaunch(wc, "testHeap"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--heap=no")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testHeapAdmin() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getHeapAdminSpinner().setSelection(30);
+ ILaunch launch = saveAndLaunch(wc, "testHeapAdmin"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--heap-admin=30")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testStacks() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getStacksButton().setSelection(true);
+ ILaunch launch = saveAndLaunch(wc, "testStacks"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--stacks=yes")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testDepth() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getDepthSpinner().setSelection(50);
+ ILaunch launch = saveAndLaunch(wc, "testDepth"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--depth=50")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testAllocFn() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getAllocFnList().add("foo"); //$NON-NLS-1$
+ ILaunch launch = saveAndLaunch(wc, "testAllocFn"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--alloc-fn=foo")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testAllocFnMultiple() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getAllocFnList().add("foo"); //$NON-NLS-1$
+ dynamicTab.getAllocFnList().add("bar"); //$NON-NLS-1$
+ ILaunch launch = saveAndLaunch(wc, "testAllocFnMultiple"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--alloc-fn=foo")); //$NON-NLS-1$
+ assertTrue(cmd.contains("--alloc-fn=bar")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testAllocFnSpace() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getAllocFnList().add("operator new(unsigned)"); //$NON-NLS-1$
+ ILaunch launch = saveAndLaunch(wc, "testAllocFnSpace"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--alloc-fn=operator new(unsigned)")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testThreshold() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getThresholdSpinner().setSelection(20);
+ ILaunch launch = saveAndLaunch(wc, "testThreshold"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--threshold=2.0")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testPeakInaccuracy() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getPeakInaccuracySpinner().setSelection(0);
+ ILaunch launch = saveAndLaunch(wc, "testPeakInaccuracy"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--peak-inaccuracy=0.0")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testTimeUnitBytes() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ String[] items = dynamicTab.getTimeUnitCombo().getItems();
+ int ix = -1;
+ for (int i = 0; i < items.length; i++) {
+ if (items[i].equals(MassifToolPage.TIME_B_STRING)) {
+ ix = i;
+ }
+ }
+ dynamicTab.getTimeUnitCombo().select(ix);
+ ILaunch launch = saveAndLaunch(wc, "testTimeUnitBytes"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--time-unit=B")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testTimeUnitMilliseconds() throws CoreException,
+ URISyntaxException, IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ String[] items = dynamicTab.getTimeUnitCombo().getItems();
+ int ix = -1;
+ for (int i = 0; i < items.length; i++) {
+ if (items[i].equals(MassifToolPage.TIME_MS_STRING)) {
+ ix = i;
+ }
+ }
+ dynamicTab.getTimeUnitCombo().select(ix);
+ ILaunch launch = saveAndLaunch(wc, "testTimeUnitMilliseconds"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--time-unit=ms")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testDetailedFreq() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getDetailedFreqSpinner().setSelection(1);
+ ILaunch launch = saveAndLaunch(wc, "testDetailedFreq"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--detailed-freq=1")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testMaxSnapshots() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+ dynamicTab.getMaxSnapshotsSpinner().setSelection(200);
+ ILaunch launch = saveAndLaunch(wc, "testMaxSpapshots"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--max-snapshots=200")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testAlignment() throws CoreException, URISyntaxException,
+ IOException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+
+ assertFalse(dynamicTab.getAlignmentSpinner().getEnabled());
+ dynamicTab.getAlignmentButton().setSelection(true);
+ dynamicTab.getAlignmentButton().notifyListeners(SWT.Selection, null);
+ assertTrue(dynamicTab.getAlignmentSpinner().getEnabled());
+
+ dynamicTab.getAlignmentSpinner().setSelection(512);
+ tab.performApply(wc);
+ config = wc.doSave();
+
+ assertTrue(tab.isValid(config));
+
+ ILaunch launch = doLaunch(config, "testAlignment"); //$NON-NLS-1$
+ IProcess[] p = launch.getProcesses();
+ assertTrue("process array should not be empty", p.length > 0);
+ String cmd = p[0].getAttribute(IProcess.ATTR_CMDLINE);
+ assertEquals(0, p[0].getExitValue());
+ assertTrue(cmd.contains("--alignment=512")); //$NON-NLS-1$
+ }
+
+ @Test
+ public void testAlignmentBad() throws CoreException {
+ ILaunchConfigurationWorkingCopy wc = initConfig();
+
+ assertFalse(dynamicTab.getAlignmentSpinner().getEnabled());
+ dynamicTab.getAlignmentButton().setSelection(true);
+ dynamicTab.getAlignmentButton().notifyListeners(SWT.Selection, null);
+ assertTrue(dynamicTab.getAlignmentSpinner().getEnabled());
+
+ dynamicTab.getAlignmentSpinner().setSelection(63);
+ tab.performApply(wc);
+ config = wc.doSave();
+
+ assertFalse(tab.isValid(config));
+ }
}

Back to the top