草庐IT

test_pack

全部标签

python - 在 Flask-SQLAlchemy 中隔离 py.test 数据库 session

我正在尝试使用Flask-SQLAlchemy构建一个Flask应用程序;我使用pytest来测试数据库。其中一个问题似乎是在不同测试之间创建隔离的数据库session。我编写了一个最小的完整示例来突出问题,请注意test_user_schema1()和test_user_schema2()是相同的。文件名:test_db.pyfrommodelsimportUserdeftest_user_schema1(session):person_name='FranClan'uu=User(name=person_name)session.add(uu)session.commit()ass

python - Perl 的 Pack ('V' ) 在 Python 中的功能?

我最近一直在进行一些漏洞利用开发,为培训类(class)做准备,但我在教程中遇到了问题。我一直在关注我能找到的所有教程,出于偏好,使用Python而不是教程使用的语言。我正在尝试对所有内容进行交叉编码,但我不知道如何对Perl的Pack()函数进行交叉编码。长话短说:我正在尝试将其翻译成python:my$file="test1.m3u";my$junk="A"x26094;my$eip=pack('V',0x000ff730);my$shellcode="\x90"x25;$shellcode=$shellcode."\xcc";$shellcode=$shellcode."\x90

python - 为什么 struct.pack 在性能上有如此高的可变性?

我在测试struct.pack的性能时得到如下结果:In[3]:%timeitpack('dddd',1.0,1.0,1.0,1.0)Theslowestruntook578.59timeslongerthanthefastest.Thiscouldmeanthatanintermediateresultisbeingcached1000000loops,bestof3:197nsperloop为什么最慢的跑得慢578倍?pack是否在进行一些内部缓存,或者这是某种CPU级缓存的结果,还是其他什么? 最佳答案 IPython分析器是

python - py.test : format failed assert AND print custom message

py.testassertdocs说...ifyouspecifyamessagewiththeassertionlikethis:asserta%2==0,"valuewasodd,shouldbeeven"thennoassertionintrospectiontakesplacesatallandthemessagewillbesimplyshowninthetraceback.Python的内置unittest模块也执行此操作,除非您的TestCase设置longMessage=True.拥有漂亮的断言格式对测试开发人员友好,而自定义消息对业务需求/人性化更友好。当您不在测试上

python - 为什么使用 packed *args/**kwargs 而不是传递 list/dict?

如果我不知道函数将传递多少个参数,我可以使用参数打包来编写函数:defadd(factor,*nums):"""Addnumbersandmultiplybyfactor."""returnsum(nums)*factor或者,我可以通过传递一个数字列表作为参数来避免参数打包:defadd(factor,nums):"""Addnumbersandmultiplybyfactor.:typefactor:int:typenums:listofint"""returnsum(nums)*factor使用参数打包*args比传递数字列表有优势吗?还是有更合适的情况?

python - 单元 : stop after first failing test?

我在我的测试框架中使用了以下代码:testModules=["test_foo","test_bar"]suite=unittest.TestLoader().loadTestsFromNames(testModules)runner=unittest.TextTestRunner(sys.stdout,verbosity=2)results=runner.run(suite)returnresults.wasSuccessful()有没有办法让报告(runner.run?)在第一次失败后中止以防止过于冗长? 最佳答案 问题提出九年

python - Django LiveServer测试用例 : User created in in setUpClass method not available in test_method?

我正在使用Django1.4的LiveServerTestCase进行Selenium测试,但在使用setUpClass类方法时遇到了问题。据我了解,MembershipTests.setUpClass在单元测试运行之前运行一次。我已经将代码添加到MembershipTests.setUpClass中的数据库,但是当我运行MembershipTests.test_signup测试时,没有用户被添加到测试中数据库。我做错了什么?我希望我在setUpClass中创建的用户在所有单元测试中都可用。如果我将用户创建代码放入MembershipTests.setUp并运行MembershipTe

python - __test__ = False 魔法属性如何用于测试发现

所以我正在尝试实现类似于单元测试框架执行以下操作的方式:classBaseTest(T.TestCase):#Disablesthistestfrombeingrun__test__=Falsedeftest_foo(self):pass#Howeverthistestispickedupbecauseitdoesn'tdirectlyhave__test__setclassInheritingTest(BaseTest):pass我觉得很奇怪:#>>InheritingTest.__test__#False这会向我表明它没有使用metaclass在构造类型时将__test__设置为T

python Nose : Log tests results to a file with Multiprocess Plugin

我正在尝试将我的测试输出记录到一个文件并同时运行它们。为此,我尝试使用多进程插件和xunit插件。我知道它们不能一起工作,xunit不会记录任何内容,因为mutiprocess不会直接发送输出。https://github.com/nose-devs/nose/issues/2我正在寻找的是允许我将输出写到文件中的任何替代方法。原因是我正在运行Selenium测试,每次出现错误时,堆栈跟踪都非常大,以至于stdout基本上被填满了。缓解的方法也可能有所帮助,关于如何配置日志输出的selenium文档非常稀少。我还尝试了一个非常基本的标准输出重定向:#nosetests>file.txt

python - 防止 setup.py test/pytest 安装额外的依赖项

在我的CI中,我有一个build步骤,它使用pip并使用私有(private)索引等正确设置。然后我有test步骤,它执行pythonsetup.pytest。在这种特殊情况下,test是pytest的别名。Setuptools和PIP以不同方式解析包依赖性,这导致测试步骤尝试重新安装某些包。我想阻止这种情况。有没有办法通过Setuptools配置(最好)或PyTest配置来做到这一点?更新:通过流行的需求repo来举例说明我遇到的问题https://github.com/vartec/example_repo_setuptools_issue 最佳答案