Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(19)

Unified Diff: tools/telemetry/third_party/rope/ropetest/advanced_oi_test.py

Issue 1132103009: Example of refactoring using rope library. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: tools/telemetry/third_party/rope/ropetest/advanced_oi_test.py
diff --git a/tools/telemetry/third_party/rope/ropetest/advanced_oi_test.py b/tools/telemetry/third_party/rope/ropetest/advanced_oi_test.py
new file mode 100644
index 0000000000000000000000000000000000000000..084fe2a773503322293e46aa93259edc0ba674be
--- /dev/null
+++ b/tools/telemetry/third_party/rope/ropetest/advanced_oi_test.py
@@ -0,0 +1,754 @@
+try:
+ import unittest2 as unittest
+except ImportError:
+ import unittest
+
+import rope.base.oi
+import rope.base.libutils
+from ropetest import testutils
+
+
+class DynamicOITest(unittest.TestCase):
+
+ def setUp(self):
+ super(DynamicOITest, self).setUp()
+ self.project = testutils.sample_project(validate_objectdb=True)
+ self.pycore = self.project.pycore
+
+ def tearDown(self):
+ testutils.remove_project(self.project)
+ super(DynamicOITest, self).tearDown()
+
+ def test_simple_dti(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func(a_func)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ self.assertEquals(pymod['a_func'].get_object(),
+ pymod['a_var'].get_object())
+
+ def test_module_dti(self):
+ mod1 = testutils.create_module(self.project, 'mod1')
+ mod2 = testutils.create_module(self.project, 'mod2')
+ code = 'import mod1\ndef a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func(mod1)\n'
+ mod2.write(code)
+ self.pycore.run_module(mod2).wait_process()
+ pymod2 = self.project.get_pymodule(mod2)
+ self.assertEquals(self.project.get_pymodule(mod1),
+ pymod2['a_var'].get_object())
+
+ def test_class_from_another_module_dti(self):
+ mod1 = testutils.create_module(self.project, 'mod1')
+ mod2 = testutils.create_module(self.project, 'mod2')
+ code1 = 'class AClass(object):\n pass\n'
+ code2 = 'from mod1 import AClass\n' \
+ '\ndef a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func(AClass)\n'
+ mod1.write(code1)
+ mod2.write(code2)
+ self.pycore.run_module(mod2).wait_process()
+ #pymod1 = self.project.get_pymodule(mod1)
+ pymod2 = self.project.get_pymodule(mod2)
+ self.assertEquals(pymod2['AClass'].get_object(),
+ pymod2['a_var'].get_object())
+
+ def test_class_dti(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class AClass(object):\n pass\n' \
+ '\ndef a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func(AClass)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ self.assertEquals(pymod['AClass'].get_object(),
+ pymod['a_var'].get_object())
+
+ def test_instance_dti(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class AClass(object):\n pass\n' \
+ '\ndef a_func(arg):\n return eval("arg()")\n' \
+ 'a_var = a_func(AClass)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ self.assertEquals(pymod['AClass'].get_object(),
+ pymod['a_var'].get_object().get_type())
+
+ def test_method_dti(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class AClass(object):\n def a_method(self, arg):\n' \
+ ' return eval("arg()")\n' \
+ 'an_instance = AClass()\n' \
+ 'a_var = an_instance.a_method(AClass)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ self.assertEquals(pymod['AClass'].get_object(),
+ pymod['a_var'].get_object().get_type())
+
+ def test_function_argument_dti(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg):\n pass\n' \
+ 'a_func(a_func)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pyscope = self.project.get_pymodule(mod).get_scope()
+ self.assertEquals(pyscope['a_func'].get_object(),
+ pyscope.get_scopes()[0]['arg'].get_object())
+
+ def test_classes_with_the_same_name(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg):\n class AClass(object):\n' \
+ ' pass\n return eval("arg")\n' \
+ 'class AClass(object):\n pass\n' \
+ 'a_var = a_func(AClass)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ self.assertEquals(pymod['AClass'].get_object(),
+ pymod['a_var'].get_object())
+
+ def test_nested_classes(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func():\n class AClass(object):\n' \
+ ' pass\n return AClass\n' \
+ 'def another_func(arg):\n return eval("arg")\n' \
+ 'a_var = another_func(a_func())\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pyscope = self.project.get_pymodule(mod).get_scope()
+ self.assertEquals(pyscope.get_scopes()[0]['AClass'].get_object(),
+ pyscope['a_var'].get_object())
+
+ def test_function_argument_dti2(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg, a_builtin_type):\n pass\n' \
+ 'a_func(a_func, [])\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pyscope = self.project.get_pymodule(mod).get_scope()
+ self.assertEquals(pyscope['a_func'].get_object(),
+ pyscope.get_scopes()[0]['arg'].get_object())
+
+ def test_dti_and_concluded_data_invalidation(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func(a_func)\n'
+ mod.write(code)
+ pymod = self.project.get_pymodule(mod)
+ pymod['a_var'].get_object()
+ self.pycore.run_module(mod).wait_process()
+ self.assertEquals(pymod['a_func'].get_object(),
+ pymod['a_var'].get_object())
+
+ def test_list_objects_and_dynamicoi(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func([C()])[0]\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_for_loops_and_dynamicoi(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'for c in a_func([C()]):\n a_var = c\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_dict_objects_and_dynamicoi(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func({1: C()})[1]\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_dict_keys_and_dynamicoi(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func({C(): 1}).keys()[0]\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_dict_keys_and_dynamicoi2(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'a, b = a_func((C1(), C2()))\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_strs_and_dynamicoi(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func("hey")\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ a_var = pymod['a_var'].get_object()
+ self.assertTrue(isinstance(a_var.get_type(), rope.base.builtins.Str))
+
+ def test_textual_transformations(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C(object):\n pass\ndef f():' \
+ '\n pass\na_var = C()\n' \
+ 'a_list = [C()]\na_str = "hey"\na_file = open("file.txt")\n'
+ mod.write(code)
+ to_pyobject = rope.base.oi.transform.TextualToPyObject(self.project)
+ to_textual = rope.base.oi.transform.PyObjectToTextual(self.project)
+ pymod = self.project.get_pymodule(mod)
+
+ def complex_to_textual(pyobject):
+ return to_textual.transform(
+ to_pyobject.transform(to_textual.transform(pyobject)))
+ for name in ('C', 'f', 'a_var', 'a_list', 'a_str', 'a_file'):
+ var = pymod[name].get_object()
+ self.assertEquals(to_textual.transform(var),
+ complex_to_textual(var))
+ self.assertEquals(to_textual.transform(pymod),
+ complex_to_textual(pymod))
+ enumerate_func = rope.base.builtins.builtins['enumerate'].get_object()
+ self.assertEquals(to_textual.transform(enumerate_func),
+ complex_to_textual(enumerate_func))
+
+ def test_arguments_with_keywords(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'a = a_func(arg=C1())\nb = a_func(arg=C2())\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_a_function_with_different_returns(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(arg):\n return eval("arg")\n' \
+ 'a = a_func(C1())\nb = a_func(C2())\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_a_function_with_different_returns2(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(p):\n if p == C1:\n return C1()\n' \
+ ' else:\n return C2()\n' \
+ 'a = a_func(C1)\nb = a_func(C2)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_ignoring_star_args(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(p, *args):' \
+ '\n if p == C1:\n return C1()\n' \
+ ' else:\n return C2()\n' \
+ 'a = a_func(C1, 1)\nb = a_func(C2, 2)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_ignoring_double_star_args(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(p, *kwds, **args):\n ' \
+ 'if p == C1:\n return C1()\n' \
+ ' else:\n return C2()\n' \
+ 'a = a_func(C1, kwd=1)\nb = a_func(C2, kwd=2)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ pymod = self.project.get_pymodule(mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_invalidating_data_after_changing(self):
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'def a_func(arg):\n return eval("arg")\n' \
+ 'a_var = a_func(a_func)\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ mod.write(code.replace('a_func', 'newfunc'))
+ mod.write(code)
+ pymod = self.project.get_pymodule(mod)
+ self.assertNotEquals(pymod['a_func'].get_object(),
+ pymod['a_var'].get_object())
+
+ def test_invalidating_data_after_moving(self):
+ mod2 = testutils.create_module(self.project, 'mod2')
+ mod2.write('class C(object):\n pass\n')
+ mod = testutils.create_module(self.project, 'mod')
+ code = 'import mod2\ndef a_func(arg):\n return eval(arg)\n' \
+ 'a_var = a_func("mod2.C")\n'
+ mod.write(code)
+ self.pycore.run_module(mod).wait_process()
+ mod.move('newmod.py')
+ pymod = self.project.get_module('newmod')
+ pymod2 = self.project.get_pymodule(mod2)
+ self.assertEquals(pymod2['C'].get_object(),
+ pymod['a_var'].get_object())
+
+
+class NewStaticOITest(unittest.TestCase):
+
+ def setUp(self):
+ super(NewStaticOITest, self).setUp()
+ self.project = testutils.sample_project(validate_objectdb=True)
+ self.pycore = self.project.pycore
+ self.mod = testutils.create_module(self.project, 'mod')
+
+ def tearDown(self):
+ testutils.remove_project(self.project)
+ super(NewStaticOITest, self).tearDown()
+
+ def test_static_oi_for_simple_function_calls(self):
+ code = 'class C(object):\n pass\ndef f(p):\n pass\nf(C())\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ f_scope = pymod['f'].get_object().get_scope()
+ p_type = f_scope['p'].get_object().get_type()
+ self.assertEquals(c_class, p_type)
+
+ def test_static_oi_not_failing_when_callin_callables(self):
+ code = 'class C(object):\n pass\nC()\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+
+ def test_static_oi_for_nested_calls(self):
+ code = 'class C(object):\n pass\ndef f(p):\n pass\n' \
+ 'def g(p):\n return p\nf(g(C()))\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ f_scope = pymod['f'].get_object().get_scope()
+ p_type = f_scope['p'].get_object().get_type()
+ self.assertEquals(c_class, p_type)
+
+ def test_static_oi_class_methods(self):
+ code = 'class C(object):\n def f(self, p):\n pass\n' \
+ 'C().f(C())'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ f_scope = c_class['f'].get_object().get_scope()
+ p_type = f_scope['p'].get_object().get_type()
+ self.assertEquals(c_class, p_type)
+
+ def test_static_oi_preventing_soi_maximum_recursion_exceptions(self):
+ code = 'item = {}\nfor item in item.keys():\n pass\n'
+ self.mod.write(code)
+ try:
+ self.pycore.analyze_module(self.mod)
+ except RuntimeError as e:
+ self.fail(str(e))
+
+ def test_static_oi_for_infer_return_typs_from_funcs_based_on_params(self):
+ code = 'class C(object):\n pass\ndef func(p):\n return p\n' \
+ 'a_var = func(C())\n'
+ self.mod.write(code)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_a_function_with_different_returns(self):
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'def a_func(arg):\n return arg\n' \
+ 'a = a_func(C1())\nb = a_func(C2())\n'
+ self.mod.write(code)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_not_reporting_out_of_date_information(self):
+ code = 'class C1(object):\n pass\n' \
+ 'def f(arg):\n return C1()\na_var = f('')\n'
+ self.mod.write(code)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+
+ self.mod.write(code.replace('C1', 'C2'))
+ pymod = self.project.get_pymodule(self.mod)
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c2_class, a_var.get_type())
+
+ def test_invalidating_concluded_data_in_a_function(self):
+ mod1 = testutils.create_module(self.project, 'mod1')
+ mod2 = testutils.create_module(self.project, 'mod2')
+ mod1.write('def func(arg):\n temp = arg\n return temp\n')
+ mod2.write('import mod1\n'
+ 'class C1(object):\n pass\n'
+ 'class C2(object):\n pass\n'
+ 'a_var = mod1.func(C1())\n')
+ pymod2 = self.project.get_pymodule(mod2)
+ c1_class = pymod2['C1'].get_object()
+ a_var = pymod2['a_var'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+
+ mod2.write(mod2.read()[:mod2.read().rfind('C1()')] + 'C2())\n')
+ pymod2 = self.project.get_pymodule(mod2)
+ c2_class = pymod2['C2'].get_object()
+ a_var = pymod2['a_var'].get_object()
+ self.assertEquals(c2_class, a_var.get_type())
+
+ def test_handling_generator_functions_for_strs(self):
+ self.mod.write('class C(object):\n pass\ndef f(p):\n yield p()\n'
+ 'for c in f(C):\n a_var = c\n')
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ # TODO: Returning a generator for functions that yield unknowns
+ @unittest.skip("Returning a generator that yields unknowns")
+ def xxx_test_handl_generator_functions_when_unknown_type_is_yielded(self):
+ self.mod.write('class C(object):\n pass'
+ '\ndef f():\n yield eval("C()")\n'
+ 'a_var = f()\n')
+ pymod = self.project.get_pymodule(self.mod)
+ a_var = pymod['a_var'].get_object()
+ self.assertTrue(isinstance(a_var.get_type(),
+ rope.base.builtins.Generator))
+
+ def test_static_oi_for_lists_depending_on_append_function(self):
+ code = 'class C(object):\n pass\nl = list()\n' \
+ 'l.append(C())\na_var = l.pop()\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_static_oi_for_lists_per_object_for_get_item(self):
+ code = 'class C(object):\n pass\nl = list()\n' \
+ 'l.append(C())\na_var = l[0]\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_static_oi_for_lists_per_object_for_fields(self):
+ code = 'class C(object):\n pass\n' \
+ 'class A(object):\n ' \
+ 'def __init__(self):\n self.l = []\n' \
+ ' def set(self):\n self.l.append(C())\n' \
+ 'a = A()\na.set()\na_var = a.l[0]\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_static_oi_for_lists_per_object_for_set_item(self):
+ code = 'class C(object):\n pass\nl = [None]\n' \
+ 'l[0] = C()\na_var = l[0]\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_static_oi_for_lists_per_object_for_extending_lists(self):
+ code = 'class C(object):\n pass\nl = []\n' \
+ 'l.append(C())\nl2 = []\nl2.extend(l)\na_var = l2[0]\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_static_oi_for_lists_per_object_for_iters(self):
+ code = 'class C(object):\n pass\n' \
+ 'l = []\nl.append(C())\n' \
+ 'for c in l:\n a_var = c\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_static_oi_for_dicts_depending_on_append_function(self):
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'd = {}\nd[C1()] = C2()\na, b = d.popitem()\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_static_oi_for_dicts_depending_on_for_loops(self):
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'd = {}\nd[C1()] = C2()\n' \
+ 'for k, v in d.items():\n a = k\n b = v\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_static_oi_for_dicts_depending_on_update(self):
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'd = {}\nd[C1()] = C2()\n' \
+ 'd2 = {}\nd2.update(d)\na, b = d2.popitem()\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_static_oi_for_dicts_depending_on_update_on_seqs(self):
+ code = 'class C1(object):\n pass\nclass C2(object):\n pass\n' \
+ 'd = {}\nd.update([(C1(), C2())])\na, b = d.popitem()\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ c2_class = pymod['C2'].get_object()
+ a_var = pymod['a'].get_object()
+ b_var = pymod['b'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+ self.assertEquals(c2_class, b_var.get_type())
+
+ def test_static_oi_for_sets_per_object_for_set_item(self):
+ code = 'class C(object):\n pass\ns = set()\n' \
+ 's.add(C())\na_var = s.pop() \n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c_class, a_var.get_type())
+
+ def test_properties_and_calling_get_property(self):
+ code = 'class C1(object):\n pass\n' \
+ 'class C2(object):\n c1 = C1()\n' \
+ ' def get_c1(self):\n return self.c1\n' \
+ ' p = property(get_c1)\nc2 = C2()\na_var = c2.p\n'
+ self.mod.write(code)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+
+ def test_soi_on_constructors(self):
+ code = 'class C1(object):\n pass\n' \
+ 'class C2(object):\n' \
+ ' def __init__(self, arg):\n self.attr = arg\n' \
+ 'c2 = C2(C1())\na_var = c2.attr'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ a_var = pymod['a_var'].get_object()
+ self.assertEquals(c1_class, a_var.get_type())
+
+ def test_not_saving_unknown_function_returns(self):
+ mod2 = testutils.create_module(self.project, 'mod2')
+ self.mod.write('class C(object):\n pass\nl = []\nl.append(C())\n')
+ mod2.write('import mod\ndef f():\n '
+ 'return mod.l.pop()\na_var = f()\n')
+ pymod = self.project.get_pymodule(self.mod)
+ pymod2 = self.project.get_pymodule(mod2)
+ c_class = pymod['C'].get_object()
+ a_var = pymod2['a_var']
+
+ self.pycore.analyze_module(mod2)
+ self.assertNotEquals(c_class, a_var.get_object().get_type())
+
+ self.pycore.analyze_module(self.mod)
+ self.assertEquals(c_class, a_var.get_object().get_type())
+
+ def test_using_the_best_callinfo(self):
+ code = 'class C1(object):\n pass\n' \
+ 'def f(arg1, arg2, arg3):\n pass\n' \
+ 'f("", None, C1())\nf("", C1(), None)\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ c1_class = pymod['C1'].get_object()
+ f_scope = pymod['f'].get_object().get_scope()
+ arg2 = f_scope['arg2'].get_object()
+ self.assertEquals(c1_class, arg2.get_type())
+
+ def test_call_function_and_parameters(self):
+ code = 'class A(object):\n def __call__(self, p):\n pass\n' \
+ 'A()("")\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ scope = self.project.get_pymodule(self.mod).get_scope()
+ p_object = scope.get_scopes()[0].get_scopes()[0]['p'].get_object()
+ self.assertTrue(isinstance(p_object.get_type(),
+ rope.base.builtins.Str))
+
+ def test_report_change_in_libutils(self):
+ self.project.prefs['automatic_soa'] = True
+ code = 'class C(object):\n pass\ndef f(p):\n pass\nf(C())\n'
+ mod_file = open(self.mod.real_path, 'w')
+ mod_file.write(code)
+ mod_file.close()
+ rope.base.libutils.report_change(self.project, self.mod.real_path, '')
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ f_scope = pymod['f'].get_object().get_scope()
+ p_type = f_scope['p'].get_object().get_type()
+ self.assertEquals(c_class, p_type)
+
+ def test_report_libutils_and_analyze_all_modules(self):
+ code = 'class C(object):\n pass\ndef f(p):\n pass\nf(C())\n'
+ self.mod.write(code)
+ rope.base.libutils.analyze_modules(self.project)
+ pymod = self.project.get_pymodule(self.mod)
+ c_class = pymod['C'].get_object()
+ f_scope = pymod['f'].get_object().get_scope()
+ p_type = f_scope['p'].get_object().get_type()
+ self.assertEquals(c_class, p_type)
+
+ def test_validation_problems_for_objectdb_retrievals(self):
+ mod1 = testutils.create_module(self.project, 'mod1')
+ mod2 = testutils.create_module(self.project, 'mod2')
+ mod1.write('l = []\nvar = l.pop()\n')
+ mod2.write('import mod1\n\nclass C(object):\n pass\n'
+ 'mod1.l.append(C())\n')
+ self.pycore.analyze_module(mod2)
+
+ pymod2 = self.project.get_pymodule(mod2)
+ c_class = pymod2['C'].get_object()
+ pymod1 = self.project.get_pymodule(mod1)
+ var_pyname = pymod1['var']
+ self.assertEquals(c_class, var_pyname.get_object().get_type())
+ mod2.write('import mod1\n\nmod1.l.append("")\n')
+ self.assertNotEquals(c_class, var_pyname.get_object().get_type(),
+ 'Class `C` no more exists')
+
+ def test_validation_problems_for_changing_builtin_types(self):
+ mod1 = testutils.create_module(self.project, 'mod1')
+ mod1.write('l = []\nl.append("")\n')
+ self.pycore.analyze_module(mod1)
+
+ mod1.write('l = {}\nv = l["key"]\n')
+ pymod1 = self.project.get_pymodule(mod1) # noqa
+ var = pymod1['v'].get_object() # noqa
+
+ def test_always_returning_containing_class_for_selfs(self):
+ code = 'class A(object):\n def f(p):\n return p\n' \
+ 'class B(object):\n pass\nb = B()\nb.f()\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod)
+ pymod = self.project.get_pymodule(self.mod)
+ a_class = pymod['A'].get_object()
+ f_scope = a_class.get_scope().get_scopes()[0]
+ p_type = f_scope['p'].get_object().get_type()
+ self.assertEquals(a_class, p_type)
+
+ def test_following_function_calls_when_asked_to(self):
+ code = 'class A(object):\n pass\n' \
+ 'class C(object):\n' \
+ ' def __init__(self, arg):\n' \
+ ' self.attr = arg\n' \
+ 'def f(p):\n return C(p)\n' \
+ 'c = f(A())\nx = c.attr\n'
+ self.mod.write(code)
+ self.pycore.analyze_module(self.mod, followed_calls=1)
+ pymod = self.project.get_pymodule(self.mod)
+ a_class = pymod['A'].get_object()
+ x_var = pymod['x'].get_object().get_type()
+ self.assertEquals(a_class, x_var)
+
+
+def suite():
+ result = unittest.TestSuite()
+ result.addTests(unittest.makeSuite(DynamicOITest))
+ result.addTests(unittest.makeSuite(NewStaticOITest))
+ return result
+
+
+if __name__ == '__main__':
+ unittest.main()
« no previous file with comments | « tools/telemetry/third_party/rope/ropetest/__init__.py ('k') | tools/telemetry/third_party/rope/ropetest/builtinstest.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698