pytest-inline: An Inline Testing Tool for Python
- URL: http://arxiv.org/abs/2305.13486v1
- Date: Mon, 22 May 2023 20:58:44 GMT
- Title: pytest-inline: An Inline Testing Tool for Python
- Authors: Yu Liu, Zachary Thurston, Alan Han, Pengyu Nie, Milos Gligoric,
Owolabi Legunsen
- Abstract summary: pytest-inline is a plugin for pytest, the most popular Python testing framework.
pytest-inline runs each inline test and fails if the target statement's output does not match the expected output.
pytest-inline is integrated into the pytest-dev organization.
- Score: 10.307253336106053
- License: http://arxiv.org/licenses/nonexclusive-distrib/1.0/
- Abstract: We present pytest-inline, the first inline testing framework for Python. We
recently proposed inline tests to make it easier to test individual program
statements. But, there is no framework-level support for developers to write
inline tests in Python. To fill this gap, we design and implement pytest-inline
as a plugin for pytest, the most popular Python testing framework. Using
pytest-inline, a developer can write an inline test by assigning test inputs to
variables in a target statement and specifying the expected test output. Then,
pytest-inline runs each inline test and fails if the target statement's output
does not match the expected output. In this paper, we describe our design of
pytest-inline, the testing features that it provides, and the intended use
cases. Our evaluation on inline tests that we wrote for 80 target statements
from 31 open-source Python projects shows that using pytest-inline incurs
negligible overhead, at 0.012x. pytest-inline is integrated into the pytest-dev
organization, and a video demo is at
https://www.youtube.com/watch?v=pZgiAxR_uJg.
Related papers
- pyMethods2Test: A Dataset of Python Tests Mapped to Focal Methods [0.21485350418225244]
Python is one of the fastest-growing programming languages and currently ranks as the top language in many lists.
It is imperative to be able to effectively train LLMs to generate good unit test cases for Python code.
This motivates the need for a large dataset to provide training and testing data.
arXiv Detail & Related papers (2025-02-07T18:19:12Z) - Detecting and Evaluating Order-Dependent Flaky Tests in JavaScript [3.6513675781808357]
Flaky tests pose a significant issue for software testing.
Previous research has identified test order dependency as one of the most prevalent causes of flakiness.
This paper aims to investigate test order dependency in JavaScript tests.
arXiv Detail & Related papers (2025-01-22T06:52:11Z) - PyPulse: A Python Library for Biosignal Imputation [58.35269251730328]
We introduce PyPulse, a Python package for imputation of biosignals in both clinical and wearable sensor settings.
PyPulse's framework provides a modular and extendable framework with high ease-of-use for a broad userbase, including non-machine-learning bioresearchers.
We released PyPulse under the MIT License on Github and PyPI.
arXiv Detail & Related papers (2024-12-09T11:00:55Z) - Do Test and Environmental Complexity Increase Flakiness? An Empirical Study of SAP HANA [47.29324864511411]
Flaky tests fail seemingly at random without changes to the code.
We study characteristics of tests and the test environment that potentially impact test flakiness.
arXiv Detail & Related papers (2024-09-16T07:52:09Z) - Observation-based unit test generation at Meta [52.4716552057909]
TestGen automatically generates unit tests, carved from serialized observations of complex objects, observed during app execution.
TestGen has landed 518 tests into production, which have been executed 9,617,349 times in continuous integration, finding 5,702 faults.
Our evaluation reveals that, when carving its observations from 4,361 reliable end-to-end tests, TestGen was able to generate tests for at least 86% of the classes covered by end-to-end tests.
arXiv Detail & Related papers (2024-02-09T00:34:39Z) - TestSpark: IntelliJ IDEA's Ultimate Test Generation Companion [15.13443954421825]
This paper introduces TestSpark, a plugin for IntelliJ IDEA that enables users to generate unit tests with only a few clicks.
TestSpark also allows users to easily modify and run each generated test and integrate them into the project workflow.
arXiv Detail & Related papers (2024-01-12T13:53:57Z) - Do Automatic Test Generation Tools Generate Flaky Tests? [12.813573907094074]
The prevalence and nature of flaky tests produced by test generation tools remain largely unknown.
We generate tests using EvoSuite (Java) and Pynguin (Python) and execute each test 200 times.
Our results show that flakiness is at least as common in generated tests as in developer-written tests.
arXiv Detail & Related papers (2023-10-08T16:44:27Z) - A Practical Toolkit for Multilingual Question and Answer Generation [79.31199020420827]
We introduce AutoQG, an online service for multilingual QAG, along with lmqg, an all-in-one Python package for model fine-tuning, generation, and evaluation.
We also release QAG models in eight languages fine-tuned on a few variants of pre-trained encoder-decoder language models, which can be used online via AutoQG or locally via lmqg.
arXiv Detail & Related papers (2023-05-27T08:42:37Z) - Learning Deep Semantics for Test Completion [46.842174440120196]
We formalize the novel task of test completion to automatically complete the next statement in a test method based on the context of prior statements and the code under test.
We develop TeCo -- a deep learning model using code semantics for test completion.
arXiv Detail & Related papers (2023-02-20T18:53:56Z) - PyGOD: A Python Library for Graph Outlier Detection [56.33769221859135]
PyGOD is an open-source library for detecting outliers in graph data.
It supports a wide array of leading graph-based methods for outlier detection.
PyGOD is released under a BSD 2-Clause license at https://pygod.org and at the Python Package Index (PyPI)
arXiv Detail & Related papers (2022-04-26T06:15:21Z) - Automated Support for Unit Test Generation: A Tutorial Book Chapter [21.716667622896193]
Unit testing is a stage of testing where the smallest segment of code that can be tested in isolation from the rest of the system is tested.
Unit tests are typically written as executable code, often in a format provided by a unit testing framework such as pytest for Python.
This chapter introduces the concept of search-based unit test generation.
arXiv Detail & Related papers (2021-10-26T11:13:40Z)
This list is automatically generated from the titles and abstracts of the papers in this site.
This site does not guarantee the quality of this site (including all information) and is not responsible for any consequences.