Exemplo n.º 1
0
        public void Calculate()
        {
            using (var calculateDlg = new CalculateIsolationSchemeDlg())
            {
                if (calculateDlg.ShowDialog(this) == DialogResult.OK)
                {
                    // Get calculated isolation windows from Calculate dialog.
                    _gridViewDriver.Items.Clear();
                    var isolationWindows = calculateDlg.IsolationWindows;
                    if (isolationWindows.Count == 0)
                    {
                        return;
                    }

                    // Determine whether isolation windows have a target and margins.
                    cbSpecifyMargin.Checked = (isolationWindows[0].StartMargin.HasValue &&
                                               !Equals(isolationWindows[0].StartMargin.Value, 0.0));

                    // Determine whether CE range is specified.
                    cbSpecifyCERange.Checked = (isolationWindows[0].CERange.HasValue);

                    // Determine if calculation was on Isolation Or Extraction
                    comboIsolation.SelectedItem = calculateDlg.IsIsolation
                        ? WindowType.MEASUREMENT
                        : WindowType.EXTRACTION;

                    // Load isolation windows into grid.
                    foreach (var window in isolationWindows)
                    {
                        _gridViewDriver.Items.Add(window);
                    }

                    // Copy multiplexed windows settings.
                    comboDeconvPre.SelectedItem = calculateDlg.Deconvolution;
                    textWindowsPerScan.Text     = calculateDlg.Multiplexed
                        ? calculateDlg.WindowsPerScan.ToString(LocalizationHelper.CurrentCulture)
                        : string.Empty;
                }
            }
        }
        // Set dialog values and check the calculated isolation window values.  Finally, OK the calculation dialog and open a fresh one.
        private void CheckWindows(Action act, params double?[] args)
        {
            RunUI(() =>
                {
                    act();
                    var isolationWindows = _calcDlg.IsolationWindows;
                    var expectedColumns = 2;
                    if (_calcDlg.MarginLeft.HasValue)
                        expectedColumns++;
                    if (_calcDlg.CERange.HasValue)
                        expectedColumns++;
                    Assert.AreEqual(isolationWindows.Count * expectedColumns, args.Length,
                        "Expected {0} isolation windows, but got {1}.", args.Length / expectedColumns, isolationWindows.Count);
                    int i = 0;
                    foreach (var window in isolationWindows)
                    {
                        CheckValue(window.Start, args[i++], "Start");
                        CheckValue(window.End, args[i++], "End");
                        if (_calcDlg.MarginLeft.HasValue)
                            CheckValue(window.StartMargin, args[i++], "Start margin");
                        if (_calcDlg.CERange.HasValue)
                            CheckValue(window.CERange, args[i++], "CE Range");
                    }
                });

            OkDialog(_calcDlg, _calcDlg.OkDialog);
            _calcDlg = ShowDialog<CalculateIsolationSchemeDlg>(_editDlg.Calculate);
        }
        protected override void DoTest()
        {
            // Display full scan tab.
            var fullScanDlg = ShowDialog<TransitionSettingsUI>(SkylineWindow.ShowTransitionSettingsUI);
            RunUI(() =>
                {
                    fullScanDlg.SelectedTab = TransitionSettingsUI.TABS.FullScan;
                    fullScanDlg.AcquisitionMethod = FullScanAcquisitionMethod.DIA;
                });

            // Open the isolation scheme dialog and calculate dialog.
            _editDlg = ShowDialog<EditIsolationSchemeDlg>(fullScanDlg.AddIsolationScheme);
            RunUI(() => _editDlg.UseResults = false);
            _calcDlg = ShowDialog<CalculateIsolationSchemeDlg>(_editDlg.Calculate);

            // Check Start values.
            CheckError(() => _calcDlg.Start = null, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_contain_a_decimal_value, 1);
            CheckError(() => _calcDlg.Start = 49, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_greater_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.Start = 2001, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_less_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.Start = 100, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_contain_a_decimal_value, 1);

            // Check End values.
            CheckError(() => _calcDlg.End = 49, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_greater_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.End = 2001, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_less_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.End = 100, Resources.CalculateIsolationSchemeDlg_OkDialog_Start_value_must_be_less_than_End_value);
            CheckError(() => _calcDlg.End = 101, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_contain_a_decimal_value, 1);

            // Check WindowWidth values.
            CheckError(() => _calcDlg.WindowWidth = 0.099, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_greater_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.WindowWidth = 1951, Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_less_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.WindowWidth = 1950, Resources.CalculateIsolationSchemeDlg_OkDialog_Window_width_must_be_less_than_or_equal_to_the_isolation_range);
            CheckError(() => _calcDlg.WindowWidth = 1);

            // Check Margin values.
            CheckError(() =>
            {
                _calcDlg.Start = 100;
                _calcDlg.End = 101;
                _calcDlg.WindowWidth = 1;
                _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.NONE;
                _calcDlg.MarginLeft = 1951;
            },
            Resources.MessageBoxHelper_ValidateDecimalTextBox__0__must_be_less_than_or_equal_to__1__, 2);
            CheckError(() => _calcDlg.MarginLeft = 1900, Resources.IsolationWindow_DoValidate_Isolation_window_margins_cover_the_entire_isolation_window_at_the_extremes_of_the_instrument_range);

            // One simple window.
            CheckWindows(() =>
                {
                    _calcDlg.Start = 100;
                    _calcDlg.End = 101;
                    _calcDlg.WindowWidth = 1;
                    _calcDlg.MarginLeft = null;
                },
                100, 101);

            // Two simple windows with overlap.
            CheckWindows(() =>
                {
                    _calcDlg.Start = 100;
                    _calcDlg.End = 101;
                    _calcDlg.WindowWidth = 1;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                },
                100, 101,
                101, 102,
                99.5, 100.5,
                100.5, 101.5);

            // One max-range window.
            CheckWindows(() =>
                {
                    _calcDlg.Start = 50;
                    _calcDlg.End = 2000;
                    _calcDlg.WindowWidth = 1950;
                },
                50, 2000);

            // One max-range window with margins.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.EXTRACTION;
                    _calcDlg.Start = 50;
                    _calcDlg.End = 2000;
                    _calcDlg.WindowWidth = 1950;
                    _calcDlg.MarginLeft = 5;
                },
                55, 1995, 5);

            // One max-range window with CE Range.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.EXTRACTION;
                    _calcDlg.Start = 50;
                    _calcDlg.End = 2000;
                    _calcDlg.WindowWidth = 1950;
                    _calcDlg.CERange = 10;
                },
                50, 2000, 10);

            // One max-range window with margin and CE Range.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.EXTRACTION;
                    _calcDlg.Start = 50;
                    _calcDlg.End = 2000;
                    _calcDlg.WindowWidth = 1950;
                    _calcDlg.MarginLeft = 5;
                    _calcDlg.CERange = 10;
                },
                55, 1995, 5, 10);

            // Now with window optimization.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.EXTRACTION;
                    _calcDlg.Start = 50;
                    _calcDlg.End = 1900;
                    _calcDlg.WindowWidth = 1850;
                    _calcDlg.MarginLeft = 5;
                    _calcDlg.OptimizeWindowPlacement = true;
                },
                55, 1901.1140, 5);

            // Overlap without window optimization. Even window width
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.MEASUREMENT;
                    _calcDlg.Start = 495;
                    _calcDlg.End = 545;
                    _calcDlg.WindowWidth = 20;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                    _calcDlg.OptimizeWindowPlacement = false;
                },
                495, 515,
                515, 535,
                535, 555,
                485, 505,
                505, 525,
                525, 545);

            // Overlap with window optimization. Even window width.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.MEASUREMENT;
                    _calcDlg.Start = 495;
                    _calcDlg.End = 545;
                    _calcDlg.WindowWidth = 20;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                    _calcDlg.OptimizeWindowPlacement = true;
                },
                495.4751, 515.4842,
                515.4842, 535.4933,
                535.4933, 555.5024,
                485.4706, 505.4796,
                505.4796, 525.4887,
                525.4887, 545.4978);

            // Overlap without window optimization. Even window width. Overlap range not divisble by overlap width.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.MEASUREMENT;
                    _calcDlg.Start = 495;
                    _calcDlg.End = 546;
                    _calcDlg.WindowWidth = 20;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                    _calcDlg.OptimizeWindowPlacement = false;
                },
                495, 515,
                515, 535,
                535, 555,
                555, 575,
                485, 505,
                505, 525,
                525, 545,
                545, 565);

            // Overlap with window optimization. Even window width. Overlap range not divisble by overlap width.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.MEASUREMENT;
                    _calcDlg.Start = 495;
                    _calcDlg.End = 546;
                    _calcDlg.WindowWidth = 20;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                    _calcDlg.OptimizeWindowPlacement = true;
                },
                495.4751, 515.4842,
                515.4842, 535.4933,
                535.4933, 555.5024,
                555.5024, 575.5115,
                485.4706, 505.4796,
                505.4796, 525.4887,
                525.4887, 545.4978,
                545.4978, 565.5069);

            // Overlap without window optimization. Odd window width.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.MEASUREMENT;
                    _calcDlg.Start = 495;
                    _calcDlg.End = 501;
                    _calcDlg.WindowWidth = 3;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                    _calcDlg.OptimizeWindowPlacement = false;
                },
                495.0, 498.0,
                498.0, 501.0,
                501.0, 504.0,
                493.5, 496.5,
                496.5, 499.5,
                499.5, 502.5);

            // Overlap with window optimization. Odd window width.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.MEASUREMENT;
                    _calcDlg.Start = 495;
                    _calcDlg.End = 501;
                    _calcDlg.WindowWidth = 3;
                    _calcDlg.Deconvolution = EditIsolationSchemeDlg.DeconvolutionMethod.OVERLAP;
                    _calcDlg.OptimizeWindowPlacement = true;
                },
                495.4751, 498.4765,
                498.4765, 501.4778,
                501.4778, 504.4792,
                494.4746, 497.4760,
                497.4760, 500.4774,
                500.4774, 503.4787);

            // Four windows that fit exactly.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.EXTRACTION;
                    _calcDlg.Start = 100;
                    _calcDlg.End = 200;
                    _calcDlg.WindowWidth = 25;
                    _calcDlg.MarginLeft = 1;
                },
                100, 125, 1,
                125, 150, 1,
                150, 175, 1,
                175, 200, 1);

            // Four windows that don't fit exactly.
            CheckWindows(() =>
                {
                    _calcDlg.WindowType = EditIsolationSchemeDlg.WindowType.EXTRACTION;
                    _calcDlg.Start = 100;
                    _calcDlg.End = 200;
                    _calcDlg.WindowWidth = 33;
                    _calcDlg.MarginLeft = 1;
                },
                100, 133, 1,
                133, 166, 1,
                166, 199, 1,
                199, 232, 1);

            // One optimized window.
            CheckWindows(() =>
                {
                    _calcDlg.Start = 100;
                    _calcDlg.End = 101;
                    _calcDlg.WindowWidth = 1;
                    _calcDlg.OptimizeWindowPlacement = true;
                },
                100.2955, 101.2959);

            // More than max number of windows.
            RunUI(() =>
                {
                    _calcDlg.Start = 100;
                    _calcDlg.End = 2000;
                    _calcDlg.WindowWidth = 1;

                    // Cover miscellaneous Get methods.
                    string x = _calcDlg.Start + _calcDlg.End + _calcDlg.WindowWidth +
                        _calcDlg.MarginLeft.ToString();
                    Assert.IsTrue(x != null); // Just using this so ReSharper won't complain.
                });

            // Cancel all dialogs to conclude test.
            OkDialog(_calcDlg, _calcDlg.CancelButton.PerformClick);
            OkDialog(_editDlg, _editDlg.CancelButton.PerformClick);
            OkDialog(fullScanDlg, fullScanDlg.CancelButton.PerformClick);
        }
 // Set dialog values, and check for the expected error message.
 private void CheckError(Action func, string errorMessage = null, int replacement = 0)
 {
     RunUI(func);
     if (errorMessage == null)
     {
         OkDialog(_calcDlg, _calcDlg.OkDialog);
         _calcDlg = ShowDialog<CalculateIsolationSchemeDlg>(_editDlg.Calculate);
     }
     else
     {
         RunDlg<MessageDlg>(_calcDlg.OkDialog, messageDlg =>
         {
             AssertEx.AreComparableStrings(errorMessage,messageDlg.Message,replacement);
             messageDlg.OkDialog();
         });
     }
 }