404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.133.133.6: ~ $
"Test outwin, coverage 76%."

from idlelib import outwin
import unittest
from test.support import requires
from tkinter import Tk, Text
from idlelib.idle_test.mock_tk import Mbox_func
from idlelib.idle_test.mock_idle import Func
from unittest import mock


class OutputWindowTest(unittest.TestCase):

    @classmethod
    def setUpClass(cls):
        requires('gui')
        root = cls.root = Tk()
        root.withdraw()
        w = cls.window = outwin.OutputWindow(None, None, None, root)
        cls.text = w.text = Text(root)

    @classmethod
    def tearDownClass(cls):
        cls.window.close()
        del cls.text, cls.window
        cls.root.destroy()
        del cls.root

    def setUp(self):
        self.text.delete('1.0', 'end')

    def test_ispythonsource(self):
        # OutputWindow overrides ispythonsource to always return False.
        w = self.window
        self.assertFalse(w.ispythonsource('test.txt'))
        self.assertFalse(w.ispythonsource(__file__))

    def test_window_title(self):
        self.assertEqual(self.window.top.title(), 'Output')

    def test_maybesave(self):
        w = self.window
        eq = self.assertEqual
        w.get_saved = Func()

        w.get_saved.result = False
        eq(w.maybesave(), 'no')
        eq(w.get_saved.called, 1)

        w.get_saved.result = True
        eq(w.maybesave(), 'yes')
        eq(w.get_saved.called, 2)
        del w.get_saved

    def test_write(self):
        eq = self.assertEqual
        delete = self.text.delete
        get = self.text.get
        write = self.window.write

        # Test bytes.
        b = b'Test bytes.'
        eq(write(b), len(b))
        eq(get('1.0', '1.end'), b.decode())

        # No new line - insert stays on same line.
        delete('1.0', 'end')
        test_text = 'test text'
        eq(write(test_text), len(test_text))
        eq(get('1.0', '1.end'), 'test text')
        eq(get('insert linestart', 'insert lineend'), 'test text')

        # New line - insert moves to next line.
        delete('1.0', 'end')
        test_text = 'test text\n'
        eq(write(test_text), len(test_text))
        eq(get('1.0', '1.end'), 'test text')
        eq(get('insert linestart', 'insert lineend'), '')

        # Text after new line is tagged for second line of Text widget.
        delete('1.0', 'end')
        test_text = 'test text\nLine 2'
        eq(write(test_text), len(test_text))
        eq(get('1.0', '1.end'), 'test text')
        eq(get('2.0', '2.end'), 'Line 2')
        eq(get('insert linestart', 'insert lineend'), 'Line 2')

        # Test tags.
        delete('1.0', 'end')
        test_text = 'test text\n'
        test_text2 = 'Line 2\n'
        eq(write(test_text, tags='mytag'), len(test_text))
        eq(write(test_text2, tags='secondtag'), len(test_text2))
        eq(get('mytag.first', 'mytag.last'), test_text)
        eq(get('secondtag.first', 'secondtag.last'), test_text2)
        eq(get('1.0', '1.end'), test_text.rstrip('\n'))
        eq(get('2.0', '2.end'), test_text2.rstrip('\n'))

    def test_writelines(self):
        eq = self.assertEqual
        get = self.text.get
        writelines = self.window.writelines

        writelines(('Line 1\n', 'Line 2\n', 'Line 3\n'))
        eq(get('1.0', '1.end'), 'Line 1')
        eq(get('2.0', '2.end'), 'Line 2')
        eq(get('3.0', '3.end'), 'Line 3')
        eq(get('insert linestart', 'insert lineend'), '')

    def test_goto_file_line(self):
        eq = self.assertEqual
        w = self.window
        text = self.text

        w.flist = mock.Mock()
        gfl = w.flist.gotofileline = Func()
        showerror = w.showerror = Mbox_func()

        # No file/line number.
        w.write('Not a file line')
        self.assertIsNone(w.goto_file_line())
        eq(gfl.called, 0)
        eq(showerror.title, 'No special line')

        # Current file/line number.
        w.write(f'{str(__file__)}: 42: spam\n')
        w.write(f'{str(__file__)}: 21: spam')
        self.assertIsNone(w.goto_file_line())
        eq(gfl.args, (str(__file__), 21))

        # Previous line has file/line number.
        text.delete('1.0', 'end')
        w.write(f'{str(__file__)}: 42: spam\n')
        w.write('Not a file line')
        self.assertIsNone(w.goto_file_line())
        eq(gfl.args, (str(__file__), 42))

        del w.flist.gotofileline, w.showerror


class ModuleFunctionTest(unittest.TestCase):

    @classmethod
    def setUp(cls):
        outwin.file_line_progs = None

    def test_compile_progs(self):
        outwin.compile_progs()
        for pat, regex in zip(outwin.file_line_pats, outwin.file_line_progs):
            self.assertEqual(regex.pattern, pat)

    @mock.patch('builtins.open')
    def test_file_line_helper(self, mock_open):
        flh = outwin.file_line_helper
        test_lines = (
            (r'foo file "testfile1", line 42, bar', ('testfile1', 42)),
            (r'foo testfile2(21) bar', ('testfile2', 21)),
            (r'  testfile3  : 42: foo bar\n', ('  testfile3  ', 42)),
            (r'foo testfile4.py :1: ', ('foo testfile4.py ', 1)),
            ('testfile5: \u19D4\u19D2: ', ('testfile5', 42)),
            (r'testfile6: 42', None),       # only one `:`
            (r'testfile7 42 text', None)    # no separators
            )
        for line, expected_output in test_lines:
            self.assertEqual(flh(line), expected_output)
            if expected_output:
                mock_open.assert_called_with(expected_output[0], 'r')


if __name__ == '__main__':
    unittest.main(verbosity=2)

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
README.txt File 8.52 KB 0644
__init__.py File 712 B 0644
htest.py File 13.67 KB 0644
mock_idle.py File 1.83 KB 0644
mock_tk.py File 11.35 KB 0644
template.py File 642 B 0644
test_autocomplete.py File 4.99 KB 0644
test_autocomplete_w.py File 709 B 0644
test_autoexpand.py File 4.53 KB 0644
test_browser.py File 7.8 KB 0644
test_calltip.py File 7.6 KB 0644
test_calltip_w.py File 686 B 0644
test_codecontext.py File 14.15 KB 0644
test_colorizer.py File 1.03 KB 0644
test_config.py File 32.04 KB 0644
test_config_key.py File 3.61 KB 0644
test_configdialog.py File 48.6 KB 0644
test_debugger.py File 571 B 0644
test_debugger_r.py File 631 B 0644
test_debugobj.py File 1.52 KB 0644
test_debugobj_r.py File 545 B 0644
test_delegator.py File 1.53 KB 0644
test_editmenu.py File 2.5 KB 0644
test_editor.py File 1.11 KB 0644
test_filelist.py File 795 B 0644
test_grep.py File 2.6 KB 0644
test_help.py File 849 B 0644
test_help_about.py File 5.68 KB 0644
test_history.py File 5.39 KB 0644
test_hyperparser.py File 8.87 KB 0644
test_iomenu.py File 870 B 0644
test_macosx.py File 3.23 KB 0644
test_mainmenu.py File 594 B 0644
test_multicall.py File 1.02 KB 0644
test_outwin.py File 5.42 KB 0644
test_paragraph.py File 14.02 KB 0644
test_parenmatch.py File 3.43 KB 0644
test_pathbrowser.py File 2.37 KB 0644
test_percolator.py File 3.97 KB 0644
test_pyparse.py File 18.15 KB 0644
test_pyshell.py File 1.28 KB 0644
test_query.py File 11.49 KB 0644
test_redirector.py File 4.08 KB 0644
test_replace.py File 8.11 KB 0644
test_rpc.py File 805 B 0644
test_rstrip.py File 1.57 KB 0644
test_run.py File 9.19 KB 0644
test_runscript.py File 777 B 0644
test_scrolledlist.py File 496 B 0644
test_search.py File 2.4 KB 0644
test_searchbase.py File 5.35 KB 0644
test_searchengine.py File 11.27 KB 0644
test_squeezer.py File 21.35 KB 0644
test_stackviewer.py File 1.18 KB 0644
test_statusbar.py File 1.11 KB 0644
test_text.py File 6.81 KB 0644
test_textview.py File 5.5 KB 0644
test_tooltip.py File 5.01 KB 0644
test_tree.py File 792 B 0644
test_undo.py File 4.13 KB 0644
test_warning.py File 2.68 KB 0644
test_window.py File 1.05 KB 0644
test_zoomheight.py File 999 B 0644