如何测试或模拟“if __name__ == '__main__””内容

发布于 2024-11-04 21:49:52 字数 468 浏览 7 评论 0原文

假设我有一个具有以下内容的模块:

def main():
    pass

if __name__ == "__main__":
    main()

我想为下半部分编写一个单元测试(我想实现 100% 的覆盖率)。我发现了 runpy 内置模块执行 import/__name__ 设置机制,但我不知道如何模拟或以其他方式检查 main( ) 函数被调用。

这是我到目前为止所尝试过的:

import runpy
import mock

@mock.patch('foobar.main')
def test_main(self, main):
    runpy.run_module('foobar', run_name='__main__')
    main.assert_called_once_with()

Say I have a module with the following:

def main():
    pass

if __name__ == "__main__":
    main()

I want to write a unit test for the bottom half (I'd like to achieve 100% coverage). I discovered the runpy builtin module that performs the import/__name__-setting mechanism, but I can't figure out how to mock or otherwise check that the main() function is called.

This is what I've tried so far:

import runpy
import mock

@mock.patch('foobar.main')
def test_main(self, main):
    runpy.run_module('foobar', run_name='__main__')
    main.assert_called_once_with()

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(13

初见终念 2024-11-11 21:49:53

我不想排除有问题的行,因此基于 这个解决方案的解释,我实现了此处给出的替代答案的简化版本...

  1. 我包装了if __name__ == "__main__": 在函数中使其易于测试,然后调用该函数以保留逻辑:
# myapp.module.py

def main():
    pass

def init():
    if __name__ == "__main__":
        main()

init()
  1. 我使用 unittest 模拟了 __name__。模拟来获取有问题的行:
from unittest.mock import patch, MagicMock
from myapp import module

def test_name_equals_main():
  # Arrange
  with patch.object(module, "main", MagicMock()) as mock_main:
    with patch.object(module, "__name__", "__main__"):
         # Act
         module.init()

  # Assert
  mock_main.assert_called_once()

如果您将参数发送到模拟函数中,就像这样,

if __name__ == "__main__":
    main(main_args)

那么您可以使用assert_used_once_with()进行更好的测试:

expected_args = ["expected_arg_1", "expected_arg_2"]
mock_main.assert_called_once_with(expected_args)

如果需要,您还可以将 return_value 添加到 MagicMock() 中,如下所示:

with patch.object(module, "main", MagicMock(return_value='foo')) as mock_main:

I did not want to exclude the lines in question, so based on this explanation of a solution, I implemented a simplified version of the alternate answer given here...

  1. I wrapped if __name__ == "__main__": in a function to make it easily testable, and then called that function to retain logic:
# myapp.module.py

def main():
    pass

def init():
    if __name__ == "__main__":
        main()

init()
  1. I mocked the __name__ using unittest.mock to get at the lines in question:
from unittest.mock import patch, MagicMock
from myapp import module

def test_name_equals_main():
  # Arrange
  with patch.object(module, "main", MagicMock()) as mock_main:
    with patch.object(module, "__name__", "__main__"):
         # Act
         module.init()

  # Assert
  mock_main.assert_called_once()

If you are sending arguments into the mocked function, like so,

if __name__ == "__main__":
    main(main_args)

then you can use assert_called_once_with() for an even better test:

expected_args = ["expected_arg_1", "expected_arg_2"]
mock_main.assert_called_once_with(expected_args)

If desired, you can also add a return_value to the MagicMock() like so:

with patch.object(module, "main", MagicMock(return_value='foo')) as mock_main:
飘落散花 2024-11-11 21:49:53

如果只是为了获得 100% 并且没有任何“真实”的东西可以测试,那么更容易忽略该行。

如果您使用常规覆盖率库,则只需添加一个简单的注释,该行将在覆盖率报告中被忽略。

if __name__ == '__main__':
    main()  # pragma: no cover

https://coverage.readthedocs.io/en/coverage-4.3.3 /exclusion.html

@Taylor Edmiston 的另一条评论也提到了它

If it's just to get the 100% and there is nothing "real" to test there, it is easier to ignore that line.

If you are using the regular coverage lib, you can just add a simple comment, and the line will be ignored in the coverage report.

if __name__ == '__main__':
    main()  # pragma: no cover

https://coverage.readthedocs.io/en/coverage-4.3.3/excluding.html

Another comment by @ Taylor Edmiston also mentions it

无声无音无过去 2024-11-11 21:49:53

一种方法是将模块作为脚本运行(例如 os.system(...))并将其 stdout 和 stderr 输出与预期值进行比较。

One approach is to run the modules as scripts (e.g. os.system(...)) and compare their stdout and stderr output to expected values.

源来凯始玺欢你 2024-11-11 21:49:53

我发现这个解决方案很有帮助。如果您使用函数来保留所有脚本代码,则效果很好。
该代码将作为一行代码进行处理。整行是否针对覆盖率计数器执行并不重要(尽管这并不是您实际期望的 100% 覆盖率)
这个技巧也被 pylint 所接受。 ;-)

if __name__ == '__main__': \
    main()

I found this solution helpful. Works well if you use a function to keep all your script code.
The code will be handled as one code line. It doesn't matter if the entire line was executed for coverage counter (though this is not what you would actually actually expect by 100% coverage)
The trick is also accepted pylint. ;-)

if __name__ == '__main__': \
    main()
凉月流沐 2024-11-11 21:49:53

你的代码对我来说似乎大部分是正确的。由于我没有找到适合我的用例的答案,因此我在这里总结我的发现。我想要一些稍微不同的东西:使用 pytest 来测试也接受参数的脚本
下面的代码应该适用于 python 3.1+,它使用 pytestrunpy,并使用 unittest 来传递参数。我没有使用 mock 因为我还不熟悉它。

测试脚本
输入脚本 totest.py
def main():
    print("Hello")

if __name__ == '__main__':
   main()
Pytest 脚本 test_totest.py
import runpy

def test_main():
    runpy.run_path('totest.py', run_name='__main__')
带参数的 Pytest 脚本

如果您使用 argparsesys,这很有用脚本中的 .argv

import unittest
import runpy

def test_main():
    with unittest.mock.patch('sys.argv', ["progname", "arg1", "arg2"]):
        runpy.run_path('totest.py', run_name='__main__')
测试模块

我也将其包含在此处以更直接地回答问题。

模块脚本 totest/__main__.py
def main():
    print("Hello")

if __name__ == '__main__':
   main()
Pytest 脚本 test_totest_module.py

这与之前的脚本几乎相同(run_module 而不是 run_path< /code>):

import runpy

def test_main():
    runpy.run_module('totest.py', run_name='__main__')
检查 main() 函数是否被调用。

在上面的示例中,main() 函数始终被调用。如果您对此表示怀疑,请随意:

  • if 中调用 main() 后添加一个 assert False:您将看到“Hello “显示在 Pytest 的标准输出日志上(这对于我的示例来说有点特定)。
  • 在 main 函数中添加一个 assert False:pytest 会让你的测试失败,证明 main 被执行了
  • 如果你想以编程方式检查它,runpy返回包含模块全局变量的字典。因此,您可以在 main() 函数中更改其中一些模块全局变量,并稍后检查它们是否已更改。您还可以使用此机制在执行 main() 后检查模块或模块全局变量的状态,这对我来说比仅仅检查函数是否被执行更有意义。

Here's a full example of the latter approach

totest/__init__.py
class Testdata:  # This is defined here so that the class is present in the module globals
    main_was_executed = False
totest/__main__.py
from . import Testdata  # Import the previously-defined class
    
def main():
    print("Hello")
    Testdata.main_was_executed = True  # Change the state of the module global

if __name__ == '__main__':
    main()
Pytest脚本 test_totest_module.py
import runpy

def test_main():
    main = runpy.run_module('totest', run_name='__main__')  # Retrieve module globals
    assert main['Testdata'].main_was_executed  # Access the member of the module global

当然,你也可以定义自己的函数来断言这一点,将其导出到模块全局变量中,并从 pytest 脚本中调用它。

Your code seems mostly correct to me. As I didn't find an answer that fit my use-case, I am summarizing my findings here. I wanted something slightly different: use pytest to test a script that also takes arguments.
The code below should work with python 3.1+, it uses pytest and runpy, with unittest for passing arguments. I didn't use mock as I am not yet familiar with it.

Testing a script
Input script totest.py
def main():
    print("Hello")

if __name__ == '__main__':
   main()
Pytest script test_totest.py
import runpy

def test_main():
    runpy.run_path('totest.py', run_name='__main__')
Pytest script with arguments

This is useful if you use argparse or sys.argv in your script:

import unittest
import runpy

def test_main():
    with unittest.mock.patch('sys.argv', ["progname", "arg1", "arg2"]):
        runpy.run_path('totest.py', run_name='__main__')
Testing a module

I also include this here to answer the question more directly.

Module script totest/__main__.py
def main():
    print("Hello")

if __name__ == '__main__':
   main()
Pytest script test_totest_module.py

This is almost the same script as before (run_module instead of run_path):

import runpy

def test_main():
    runpy.run_module('totest.py', run_name='__main__')
Checking that the main() function was called.

With the above examples, the main() function is always called. If you doubt this, feel free to:

  • add an assert False after the call to main() in the if: you will see "Hello" displayed on Pytest's stdout log (this is a bit specific to my example).
  • add an assert False in the main function: pytest will fail your test, proving that main was executed
  • If you want to check it programmatically, runpy returns the a dictionary containing the module globals. Therefore, you can change some of these module globals in the main() function and check that they were changed later. You can also use this mechanism to inspect the state of your module or module globals after executing main(), which makes more sense to me than just checking if the function was executed.

Here's a full example of the latter approach

totest/__init__.py
class Testdata:  # This is defined here so that the class is present in the module globals
    main_was_executed = False
totest/__main__.py
from . import Testdata  # Import the previously-defined class
    
def main():
    print("Hello")
    Testdata.main_was_executed = True  # Change the state of the module global

if __name__ == '__main__':
    main()
Pytest script test_totest_module.py
import runpy

def test_main():
    main = runpy.run_module('totest', run_name='__main__')  # Retrieve module globals
    assert main['Testdata'].main_was_executed  # Access the member of the module global

Of course, you can also define your own function to assert this, export it in the module globals, and call it from the pytest script.

捂风挽笑 2024-11-11 21:49:53

我的解决方案是使用 imp.load_source() 并通过不提供必需的 CLI 参数、提供格式错误的参数、设置来强制在 main() 中尽早引发异常路径以找不到所需文件的方式等。

import imp    
import os
import sys

def mainCond(testObj, srcFilePath, expectedExcType=SystemExit, cliArgsStr=''):
    sys.argv = [os.path.basename(srcFilePath)] + (
        [] if len(cliArgsStr) == 0 else cliArgsStr.split(' '))
    testObj.assertRaises(expectedExcType, imp.load_source, '__main__', srcFilePath)

然后在您的测试类中,您可以像这样使用此函数:

def testMain(self):
    mainCond(self, 'path/to/main.py', cliArgsStr='-d FailingArg')

My solution is to use imp.load_source() and force an exception to be raised early in main() by not providing a required CLI argument, providing a malformed argument, setting paths in such a way that a required file is not found, etc.

import imp    
import os
import sys

def mainCond(testObj, srcFilePath, expectedExcType=SystemExit, cliArgsStr=''):
    sys.argv = [os.path.basename(srcFilePath)] + (
        [] if len(cliArgsStr) == 0 else cliArgsStr.split(' '))
    testObj.assertRaises(expectedExcType, imp.load_source, '__main__', srcFilePath)

Then in your test class you can use this function like this:

def testMain(self):
    mainCond(self, 'path/to/main.py', cliArgsStr='-d FailingArg')
叫思念不要吵 2024-11-11 21:49:53

要在 pytest 中导入“ma​​in”代码以进行测试,您可以像其他函数一样导入主模块,这要归功于本机 importlib 包:

def test_main():
    import importlib
    loader = importlib.machinery.SourceFileLoader("__main__", "src/glue_jobs/move_data_with_resource_partitionning.py")
    runpy_main = loader.load_module()
    assert runpy_main()

To import your "main" code in pytest in order to test it you can import main module like other functions thanks to native importlib package :

def test_main():
    import importlib
    loader = importlib.machinery.SourceFileLoader("__main__", "src/glue_jobs/move_data_with_resource_partitionning.py")
    runpy_main = loader.load_module()
    assert runpy_main()
谎言 2024-11-11 21:49:53

由于 imp 已被弃用,因此这里有一个 importlib 版本,以及命令行参数模拟。在exec_module之后,foobar将被完全初始化,并且foobar.main已经被执行。

import sys
class MyTest(unittest.TestCase):
    def test_main(self):
        import importlib.util
        from unittest.mock import patch

        testargs = ['foobar.py']
        with patch.object(sys, 'argv', testargs):
            spec = importlib.util.spec_from_file_location('__main__', 'foobar.py')
            runpy = importlib.util.module_from_spec(spec)
            spec.loader.exec_module(runpy)
            # check result of foobar script in unittest from here
            self.assertIsNotNone(runpy)

As imp is deprecated, here is a importlib version, along with commandline arguments mock. After the exec_module, foobar would have been fully initiallized, and foobar.main has already been exectued.

import sys
class MyTest(unittest.TestCase):
    def test_main(self):
        import importlib.util
        from unittest.mock import patch

        testargs = ['foobar.py']
        with patch.object(sys, 'argv', testargs):
            spec = importlib.util.spec_from_file_location('__main__', 'foobar.py')
            runpy = importlib.util.module_from_spec(spec)
            spec.loader.exec_module(runpy)
            # check result of foobar script in unittest from here
            self.assertIsNotNone(runpy)
辞慾 2024-11-11 21:49:53

有人欣赏一点横向思维吗?

def test_if_file_name_main_main_function_is_called():
    main_file_path = pathlib.Path.cwd().joinpath('__main__.py')
    with main_file_path.open(mode='r', encoding='utf-8') as f:
        content = f.read()
    pattern = '.*\nif\s+__name__\s*==\s*[\'"]__main__[\'"]\s*:\s*\n\s+main\(\)\s*\n.*'
    assert re.fullmatch(pattern, content, flags=re.DOTALL) != None

我希望这能引起笑声。

我个人不太关心覆盖工具。

但我实际上建议今后将其纳入我的项目中。令我烦恼的是,我的应用程序可能会在交付时缺少一对对其功能至关重要的行,但却通过了所有测试。

我欣然接受这并不完美(例如,可以在多行注释中找到匹配的字符串),但恕我直言,这总比没有好。

PS,您还可以免费获得 UTF-8 编码的基本奖励检查...

Anyone appreciate a bit of lateral thinking?

def test_if_file_name_main_main_function_is_called():
    main_file_path = pathlib.Path.cwd().joinpath('__main__.py')
    with main_file_path.open(mode='r', encoding='utf-8') as f:
        content = f.read()
    pattern = '.*\nif\s+__name__\s*==\s*[\'"]__main__[\'"]\s*:\s*\n\s+main\(\)\s*\n.*'
    assert re.fullmatch(pattern, content, flags=re.DOTALL) != None

I hope that raises a laugh.

I'm personally not bothered much about coverage tools.

But I'm actually proposing to include this henceforth in my projects. It bugs me that my app could potentially be shipped with a pair of lines missing which are essential to its functioning, but pass all tests.

I readily accept that this ain't perfect (for example, the matching string could be found inside a multi-line comment), but it's better than nothing, IMHO.

PS you also get a basic bonus check on UTF-8 encoding thrown in for free...

晨曦慕雪 2024-11-11 21:49:52

我将选择另一种选择,即从覆盖率报告中排除 if __name__ == '__main__' ,当然,只有当您已经有 main() 函数的测试用例时,您才可以这样做你的测试。

至于为什么我选择排除而不是为整个脚本编写一个新的测试用例,是因为如果正如我所说,您已经有一个针对您的 main() 函数的测试用例,那么您添加另一个测试用例脚本的测试用例(仅用于 100% 覆盖率)将只是一个重复的测试用例。

对于如何排除 if __name__ == '__main__' ,您可以编写一个覆盖率配置文件并在部分报告中添加:

[report]

exclude_lines =
    if __name__ == .__main__.:

有关覆盖率配置文件的更多信息可以找到此处

希望这能有所帮助。

I will choose another alternative which is to exclude the if __name__ == '__main__' from the coverage report , of course you can do that only if you already have a test case for your main() function in your tests.

As for why I choose to exclude rather than writing a new test case for the whole script is because if as I stated you already have a test case for your main() function the fact that you add an other test case for the script (just for having a 100 % coverage) will be just a duplicated one.

For how to exclude the if __name__ == '__main__' you can write a coverage configuration file and add in the section report:

[report]

exclude_lines =
    if __name__ == .__main__.:

More info about the coverage configuration file can be found here.

Hope this can help.

做个少女永远怀春 2024-11-11 21:49:52

您可以使用 imp 模块而不是 import 语句来执行此操作。 import 语句的问题在于,在您有机会分配给 runpy.__name__< 之前,对 '__main__' 的测试会作为 import 语句的一部分运行。 /代码>。

例如,您可以像这样使用 imp.load_source()

import imp
runpy = imp.load_source('__main__', '/path/to/runpy.py')

第一个参数分配给导入模块的 __name__

You can do this using the imp module rather than the import statement. The problem with the import statement is that the test for '__main__' runs as part of the import statement before you get a chance to assign to runpy.__name__.

For example, you could use imp.load_source() like so:

import imp
runpy = imp.load_source('__main__', '/path/to/runpy.py')

The first parameter is assigned to __name__ of the imported module.

梦在深巷 2024-11-11 21:49:52

哇,我参加聚会有点晚了,但我最近遇到了这个问题,我想我想出了一个更好的解决方案,所以这就是......

我正在开发一个包含十几个脚本的模块一切都以这个完全相同的copypasta结尾:

if __name__ == '__main__':
    if '--help' in sys.argv or '-h' in sys.argv:
        print(__doc__)
    else:
        sys.exit(main())

当然,不可怕,但也无法测试。我的解决方案是在我的一个模块中编写一个新函数:

def run_script(name, doc, main):
    """Act like a script if we were invoked like a script."""
    if name == '__main__':
        if '--help' in sys.argv or '-h' in sys.argv:
            sys.stdout.write(doc)
        else:
            sys.exit(main())

然后将此 gem 放在每个脚本文件的末尾:

run_script(__name__, __doc__, main)

从技术上讲,无论您的脚本是作为模块导入还是作为脚本运行,该函数都将无条件运行。不过,这没关系,因为除非脚本作为脚本运行,否则该函数实际上不会执行任何操作。因此,代码覆盖率看到函数运行后会说“是的,100% 代码覆盖率!”同时,我编写了三个测试来覆盖函数本身:

@patch('mymodule.utils.sys')
def test_run_script_as_import(self, sysMock):
    """The run_script() func is a NOP when name != __main__."""
    mainMock = Mock()
    sysMock.argv = []
    run_script('some_module', 'docdocdoc', mainMock)
    self.assertEqual(mainMock.mock_calls, [])
    self.assertEqual(sysMock.exit.mock_calls, [])
    self.assertEqual(sysMock.stdout.write.mock_calls, [])

@patch('mymodule.utils.sys')
def test_run_script_as_script(self, sysMock):
    """Invoke main() when run as a script."""
    mainMock = Mock()
    sysMock.argv = []
    run_script('__main__', 'docdocdoc', mainMock)
    mainMock.assert_called_once_with()
    sysMock.exit.assert_called_once_with(mainMock())
    self.assertEqual(sysMock.stdout.write.mock_calls, [])

@patch('mymodule.utils.sys')
def test_run_script_with_help(self, sysMock):
    """Print help when the user asks for help."""
    mainMock = Mock()
    for h in ('-h', '--help'):
        sysMock.argv = [h]
        run_script('__main__', h*5, mainMock)
        self.assertEqual(mainMock.mock_calls, [])
        self.assertEqual(sysMock.exit.mock_calls, [])
        sysMock.stdout.write.assert_called_with(h*5)

Blam!现在您可以编写一个可测试的 main(),将其作为脚本调用,拥有 100% 的测试覆盖率,并且不需要忽略覆盖率报告中的任何代码。

Whoa, I'm a little late to the party, but I recently ran into this issue and I think I came up with a better solution, so here it is...

I was working on a module that contained a dozen or so scripts all ending with this exact copypasta:

if __name__ == '__main__':
    if '--help' in sys.argv or '-h' in sys.argv:
        print(__doc__)
    else:
        sys.exit(main())

Not horrible, sure, but not testable either. My solution was to write a new function in one of my modules:

def run_script(name, doc, main):
    """Act like a script if we were invoked like a script."""
    if name == '__main__':
        if '--help' in sys.argv or '-h' in sys.argv:
            sys.stdout.write(doc)
        else:
            sys.exit(main())

and then place this gem at the end of each script file:

run_script(__name__, __doc__, main)

Technically, this function will be run unconditionally whether your script was imported as a module or ran as a script. This is ok however because the function doesn't actually do anything unless the script is being ran as a script. So code coverage sees the function runs and says "yes, 100% code coverage!" Meanwhile, I wrote three tests to cover the function itself:

@patch('mymodule.utils.sys')
def test_run_script_as_import(self, sysMock):
    """The run_script() func is a NOP when name != __main__."""
    mainMock = Mock()
    sysMock.argv = []
    run_script('some_module', 'docdocdoc', mainMock)
    self.assertEqual(mainMock.mock_calls, [])
    self.assertEqual(sysMock.exit.mock_calls, [])
    self.assertEqual(sysMock.stdout.write.mock_calls, [])

@patch('mymodule.utils.sys')
def test_run_script_as_script(self, sysMock):
    """Invoke main() when run as a script."""
    mainMock = Mock()
    sysMock.argv = []
    run_script('__main__', 'docdocdoc', mainMock)
    mainMock.assert_called_once_with()
    sysMock.exit.assert_called_once_with(mainMock())
    self.assertEqual(sysMock.stdout.write.mock_calls, [])

@patch('mymodule.utils.sys')
def test_run_script_with_help(self, sysMock):
    """Print help when the user asks for help."""
    mainMock = Mock()
    for h in ('-h', '--help'):
        sysMock.argv = [h]
        run_script('__main__', h*5, mainMock)
        self.assertEqual(mainMock.mock_calls, [])
        self.assertEqual(sysMock.exit.mock_calls, [])
        sysMock.stdout.write.assert_called_with(h*5)

Blam! Now you can write a testable main(), invoke it as a script, have 100% test coverage, and not need to ignore any code in your coverage report.

等数载,海棠开 2024-11-11 21:49:52

Python 3 解决方案:

import os
from importlib.machinery import SourceFileLoader
from importlib.util import spec_from_loader, module_from_spec
from importlib import reload
from unittest import TestCase
from unittest.mock import MagicMock, patch
    

class TestIfNameEqMain(TestCase):
    def test_name_eq_main(self):
        loader = SourceFileLoader('__main__',
                                  os.path.join(os.path.dirname(os.path.dirname(__file__)),
                                               '__main__.py'))
        with self.assertRaises(SystemExit) as e:
            loader.exec_module(module_from_spec(spec_from_loader(loader.name, loader)))

使用定义自己的小函数的替代解决方案:

# module.py
def main():
    if __name__ == '__main__':
        return 'sweet'
    return 'child of mine'

您可以使用以下方法进行测试:

# Override the `__name__` value in your module to '__main__'
with patch('module_name.__name__', '__main__'):
    import module_name
    self.assertEqual(module_name.main(), 'sweet')

with patch('module_name.__name__', 'anything else'):
    reload(module_name)
    del module_name
    import module_name
    self.assertEqual(module_name.main(), 'child of mine')

Python 3 solution:

import os
from importlib.machinery import SourceFileLoader
from importlib.util import spec_from_loader, module_from_spec
from importlib import reload
from unittest import TestCase
from unittest.mock import MagicMock, patch
    

class TestIfNameEqMain(TestCase):
    def test_name_eq_main(self):
        loader = SourceFileLoader('__main__',
                                  os.path.join(os.path.dirname(os.path.dirname(__file__)),
                                               '__main__.py'))
        with self.assertRaises(SystemExit) as e:
            loader.exec_module(module_from_spec(spec_from_loader(loader.name, loader)))

Using the alternative solution of defining your own little function:

# module.py
def main():
    if __name__ == '__main__':
        return 'sweet'
    return 'child of mine'

You can test with:

# Override the `__name__` value in your module to '__main__'
with patch('module_name.__name__', '__main__'):
    import module_name
    self.assertEqual(module_name.main(), 'sweet')

with patch('module_name.__name__', 'anything else'):
    reload(module_name)
    del module_name
    import module_name
    self.assertEqual(module_name.main(), 'child of mine')
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文