Assessing Mock Classes: an Empirical Study
Total Page:16
File Type:pdf, Size:1020Kb
Load more
Recommended publications
-
CITS5501 Software Testing and Quality Assurance Test Automation
Test automation Test cases CITS5501 Software Testing and Quality Assurance Test Automation Unit coordinator: Arran Stewart 1 / 111 Test automation Test cases Re-cap We looked at testing concepts – failures, faults/defects, and erroneous states We looked at specifications and APIs – these help us answer the question, “How do we know what to test against?” i.e., What is the correct behaviour for some piece of software? We have discussed what unit tests are, and what they look like 2 / 111 Test automation Test cases Questions What’s the structure of a test? How do different types of test relate? How do we come up with tests? How do we know when we have enough tests? What are typical patterns and techniques when writing tests? How do we deal with difficult-to-test software? (e.g. software components with many dependencies) What sorts of things can be tested? 3 / 111 Test automation Test cases Questions What’s the structure of a test? Any test can be seen, roughly, as asking: “When set up appropriately – if the system (or some part of it) is asked to do X, does its actual behaviour match the expected behaviour?” 4 / 111 Test automation Test cases Test structure That is, we can see any test as consisting of two things: Test values: anything required to set up the system (or some part of it), and “ask it do” something, and observe the result. Expected values: what the system is expected to do. “Values” is being used in a very broad sense. Suppose we are designing system tests for a phone – then the “test values” might include, in some cases, physical actions to be done by a tester to put the phone in a particular state (e.g. -
From Zero to 1000 Tests in 6 Months
From Zero to 1000 tests in 6 months Or how not to lose your mind with 2 week iterations Name is Max Vasilyev Senior Developer and QA Manager at Solutions Aberdeen http://tech.trailmax.info @trailmax Business Does Not Care • Business does not care about tests. • Business does not care about internal software quality. • Business does not care about architecture. • Some businesses don’t care so much, they even don’t care about money. Don’t Tell The Business Just do it! Just write your tests, ask no one. Honestly, tomorrow in the office just create new project, add NUnit package and write a test. That’ll take you 10 minutes. Simple? Writing a test is simple. Writing a good test is hard. Main questions are: – What do you test? – Why do you test? – How do you test? Our Journey: Stone Age Started with Selenium browser tests: • Recording tool is OK to get started • Boss loved it! • Things fly about on the screen - very dramatic But: • High maintenance effort • Problematic to check business logic Our Journey: Iron Age After initial Selenium fever, moved on to integration tests: • Hook database into tests and part-test database. But: • Very difficult to set up (data + infrastructure) • Problematic to test logic Our Journey: Our Days • Now no Selenium tests • A handful of integration tests • Most of the tests are unit-ish* tests • 150K lines of code in the project • Around 1200 tests with 30% coverage** • Tests are run in build server * Discuss Unit vs Non-Unit tests later ** Roughly 1 line of test code covers 2 lines of production code Testing Triangle GUI Tests GUI Tests Integration Tests Integration Tests Unit Tests Unit Tests Our Journey: 2 Week Iterations? The team realised tests are not optional after first 2-week iteration: • There simply was no time to manually test everything at the end of iteration. -
Designpatternsphp Documentation Release 1.0
DesignPatternsPHP Documentation Release 1.0 Dominik Liebler and contributors Jul 18, 2021 Contents 1 Patterns 3 1.1 Creational................................................3 1.1.1 Abstract Factory........................................3 1.1.2 Builder.............................................8 1.1.3 Factory Method......................................... 13 1.1.4 Pool............................................... 18 1.1.5 Prototype............................................ 21 1.1.6 Simple Factory......................................... 24 1.1.7 Singleton............................................ 26 1.1.8 Static Factory.......................................... 28 1.2 Structural................................................. 30 1.2.1 Adapter / Wrapper....................................... 31 1.2.2 Bridge.............................................. 35 1.2.3 Composite............................................ 39 1.2.4 Data Mapper.......................................... 42 1.2.5 Decorator............................................ 46 1.2.6 Dependency Injection...................................... 50 1.2.7 Facade.............................................. 53 1.2.8 Fluent Interface......................................... 56 1.2.9 Flyweight............................................ 59 1.2.10 Proxy.............................................. 62 1.2.11 Registry............................................. 66 1.3 Behavioral................................................ 69 1.3.1 Chain Of Responsibilities................................... -
Stream-Based Verification with Junit
Stream-Based Verification with JUnit Strombasierte Verifikation mit JUnit Masterarbeit Im Rahmen des Studiengangs Vorgelegt von Ausgegeben und betreut von Informatik Denis-Michael Lux Prof. Dr. Martin Leucker der Universität zu Lübeck mit Unterstützung von Malte Schmitz, M.Sc. Dipl.-Inf. Daniel Thoma Lübeck, den 14. Juni 2019 Selbstständigkeitserklärung Der Verfasser versichert an Eides statt, dass er die vorliegende Arbeit selbständig, ohne fremde Hilfe und ohne Benutzung anderer als der angegebenen Hilfsmittel angefertigt hat. Die aus fremden Quellen (einschließlich elektronischer Quellen) direkt oder indirekt über- nommenen Gedanken sind ausnahmslos als solche kenntlich gemacht. Die Arbeit ist in gle- icher oder ähnlicher Form oder auszugsweise im Rahmen einer anderen Prüfung noch nicht vorgelegt worden. Ort/Datum Unterschrift des Verfassers Contents Introduction 1 1 Unit Testing and Mocking in JUnit 3 1.1 Unit Testing ................................... 4 1.2 The JUnit Testing Framework ......................... 4 1.3 Assertions .................................... 8 1.4 Mocks and Stubs ................................ 10 2 Stream Runtime Verification 13 2.1 Runtime Verfication .............................. 13 2.2 Stream Processing ............................... 14 2.3 Temporal Stream-based Specification Language (TeSSLa) .......... 20 3 TeSSLa-Based Monitoring and Mocking in JUnit 25 3.1 Application Code Instrumentation ...................... 25 3.2 Monitors for Test Cases and Test Suites .................... 28 3.3 Class and Interface -
Autonomic Test Case Generation of Failing Code Using AOP By
Autonomic Test Case Generation of Failing Code Using AOP by Giovanni Murguia B.Sc., Instituto Tecnol´ogicoy de Estudios Superiores de Monterrey, Mexico 2008 A Thesis Submitted in Partial Fulfillment of the Requirements for the Degree of Master of Science in the Department of Computer Science c Giovanni Murguia, 2020 University of Victoria All rights reserved. This thesis may not be reproduced in whole or in part, by photocopying or other means, without the permission of the author. ii Autonomic Test Case Generation of Failing Code Using AOP by Giovanni Murguia B.Sc., Instituto Tecnol´ogicoy de Estudios Superiores de Monterrey, Mexico 2008 Supervisory Committee Dr. Hausi A. M¨uller,Supervisor (Department of Computer Science) Dr. Alex I. Thomo, Departamental Member (Department of Computer Science) iii Supervisory Committee Dr. Hausi A. M¨uller,Supervisor (Department of Computer Science) Dr. Alex I. Thomo, Departamental Member (Department of Computer Science) ABSTRACT As software systems have grown in size and complexity, the costs of maintaining such systems increases steadily. In the early 2000's, IBM launched the autonomic com- puting initiative to mitigate this problem by injecting feedback control mechanisms into software systems to enable them to observe their health and self-heal without human intervention and thereby cope with certain changes in their requirements and environments. Self-healing is one of several fundamental challenges addressed and includes software systems that are able to recover from failure conditions. There has been considerable research on software architectures with feedback loops that allow a multi-component system to adjust certain parameters automatically in response to changes in its environment. -
Carmine Vassallo
Automated Testing Carmine Vassallo [email protected] @ccvassallo Recommended Book Gerard Meszaros, xUnit Test Patterns: Refactoring Test Code (Martin Fowler Signature Book) Addison-Wesley, 2007 2 Software Bugs “A software bug is an error, flaw, failure or fault in a computer program or system that causes it to produce an incorrect or unexpected result, or to behave in unintended ways.” https://en.wikipedia.org/wiki/Software_bug 3 How to detect bugs? Testing • Testing is the activity of finding out whether a piece of code (a method, class, or program) produces the intended behaviour. • We test software because we are sure it has bugs in it! • The feedback provided by testing is very valuable, but if it comes so late in the development cycle, its value is greatly diminished. • We need to continuously check for defects in our code. 4 The LEAN process http://thecommunitymanager.com/2012/08/01/the-lean-community/ 5 Automated SW Testing • Automated Software Testing consists of using special software (separate from the software being tested) to control the execution of tests and the comparison of actual outcomes with predicted outcomes. • Test automation can automate some repetitive but necessary tasks in a formalized testing process already in place, or perform additional testing that would be difficult to do manually. • Test automation is critical for continuous delivery and continuous testing. 6 Goals of Automated Testing (1/2) • Tests should help us improve quality. • If we are doing test-driven development or test-first development, the tests give us a way to capture what the SUT should be doing before we start building it. -
Test-‐Driven Development Step Patterns for Designing Objects
Test-Driven Development Step Patterns For Designing Objects Dependencies EDUARDO GUERRA, National Institute for Space Research, Brazil JOSEPH YODER, Refactory Inc., USA MAURÍCIO FINAVARO ANICHE, University of São Paulo, Brazil MARCO AURÉLIO GEROSA, University of São Paulo, Brazil Test-driven development (TDD) is a development technique often used to design classes in a software system by creating tests before their actual code. The dependency management and class APIs decisions, that emerge during the practice of TDD, does not "just happen": the way that the tests are created should be used in this process to make decisions and drive the design in the desired direction. This paper introduces four patterns that document the kinds of TDD cycles that can be performed to guide the design in the desired direction. These patterns are part of a pattern language that intends to present recurrent solutions that are used in a TDD process. Categories and Subject Descriptors: D.1.5 [Programming Techniques]: Object-oriented Programming; D.2.11 [Software Architectures]: Patterns General Terms: Test driven development Additional Key Words and Phrases: TDD, softWare design, patterns ACM Reference Format: Guerra, E., Yoder, J., Aniche, M. and Gerosa, M.. 2013. Test-Driven Development Step Patterns For Designing Objects Dependencies. Proceedings of the 20th Conference on Pattern Languages of Programs (PLoP). October 2013, 15 pages. 1. INTRODUCTION Test-driven development (TDD) is a technique in Which the tests are Written before the production code (Beck 2002). By using it, the development occurs in cycles, comprised of the creation of an automated test, an update on the developed softWare to make the test pass, and a code refactoring to improve the solution. -
ABAP to the Future 864 Pages, 2019, $79.95 ISBN 978-1-4932-1761-8
First-hand knowledge. Browse the Book This chapter covers eliminating dependencies in your existing programs, implementing test doubles, and using ABAP Unit to write and implement test classes. It also includes advice on how to improve test-driven development via automated frameworks. ABAP Unit and Test-Driven Development Table of Contents Index The Author Paul Hardy ABAP to the Future 864 Pages, 2019, $79.95 ISBN 978-1-4932-1761-8 www.sap-press.com/4751 Chapter 5 ABAP Unit and Test-Driven Development 5 “Code without tests is bad code. It doesn’t matter how well-written it is; it doesn’t matter how pretty or object-oriented or well-encapsulated it is. With tests, we can change the behavior of our code quickly and verifiably. Without them, we really don’t know if our code is getting better or worse.” —Michael Feathers, Working Effectively with Legacy Code Programs have traditionally been fragile; that is, any sort of change was likely to break something, potentially causing massive damage. You want to reverse this situ- ation so that you can make as many changes as the business requires as fast as you can with zero risk. The way to do this is via test-driven development (TDD), supported by the ABAP Unit tool. This chapter explains what TDD is and how to enable it via the ABAP Unit framework. In the traditional development process, you write a new program or change an exist- ing one, and after you’re finished you perform some basic tests, and then you pass the program on to QA to do some proper testing. -
To Mock Or Not to Mock?
Delft University of Technology To Mock or Not To Mock? An Empirical Study on Mocking Practices Spadini, Davide; Aniche, Maurício; Bruntink, Magiel; Bacchelli, Alberto DOI 10.1109/MSR.2017.61 Publication date 2017 Document Version Accepted author manuscript Published in Proceedings - 2017 IEEE/ACM 14th International Conference on Mining Software Repositories, MSR 2017 Citation (APA) Spadini, D., Aniche, M., Bruntink, M., & Bacchelli, A. (2017). To Mock or Not To Mock? An Empirical Study on Mocking Practices. In Proceedings - 2017 IEEE/ACM 14th International Conference on Mining Software Repositories, MSR 2017 (pp. 402-412). [7962389] IEEE . https://doi.org/10.1109/MSR.2017.61 Important note To cite this publication, please use the final published version (if applicable). Please check the document version above. Copyright Other than for strictly personal use, it is not permitted to download, forward or distribute the text or part of it, without the consent of the author(s) and/or copyright holder(s), unless the work is under an open content license such as Creative Commons. Takedown policy Please contact us and provide details if you believe this document breaches copyrights. We will remove access to the work immediately and investigate your claim. This work is downloaded from Delft University of Technology. For technical reasons the number of authors shown on this cover page is limited to a maximum of 10. Delft University of Technology Software Engineering Research Group Technical Report Series To Mock or Not To Mock? An Empirical Study -
Private API Access and Functional Mocking in Automated Unit Test Generation
Private API Access and Functional Mocking in Automated Unit Test Generation Andrea Arcuri Gordon Fraser René Just Westerdals Oslo ACT University of Sheffield University of Massachusetts Oslo, Norway, Sheffield, UK Amherst, MA, USA and SnT, University of Luxembourg Abstract—Not all object oriented code is easily testable: 1 public interface AnInterface { Dependency objects might be difficult or even impossible to 2 boolean isOK(); instantiate, and object-oriented encapsulation makes testing po- 3 } tentially simple code difficult if it cannot easily be accessed. 4 5 public class PAFM { When this happens, then developers can resort to mock objects 6 that simulate the complex dependencies, or circumvent object- 7 public void example(AnInterface x) { oriented encapsulation and access private APIs directly through 8 if(System.getProperty("user.name").equals("root")) { the use of, for example, Java reflection. Can automated unit test 9 checkIfOK(x); 10 } generation benefit from these techniques as well? In this paper 11 } we investigate this question by extending the EvoSuite unit test 12 generation tool with the ability to directly access private APIs 13 private boolean checkIfOK(AnInterface x){ and to create mock objects using the popular Mockito framework. 14 if(x.isOK()){ 15 return true; However, care needs to be taken that this does not impact the 16 } else{ usefulness of the generated tests: For example, a test accessing a 17 return false; private field could later fail if that field is renamed, even if that 18 } renaming is part of a semantics-preserving refactoring. Such a 19 } } failure would not be revealing a true regression bug, but is a 20 false positive, which wastes the developer’s time for investigating and fixing the test. -
Automated Unit Test Generation for Classes with Environment Dependencies
Automated Unit Test Generation for Classes with Environment Dependencies Andrea Arcuri Gordon Fraser Juan Pablo Galeotti Certus Software V&V Center University of Sheffield Saarland University – Simula Research Laboratory Dep. of Computer Science Computer Science Lysaker, Norway Sheffield, UK Saarbrücken, Germany ABSTRACT 1 public class EnvExample { 2 Automated test generation for object-oriented software typically 3 public boolean checkContent() throws Exception{ consists of producing sequences of calls aiming at high code cov- 4 erage. In practice, the success of this process may be inhibited 5 Scanner console = new Scanner(System.in); when classes interact with their environment, such as the file sys- 6 String fileName = console.nextLine(); 7 console.close(); tem, network, user-interactions, etc. This leads to two major prob- 8 lems: First, code that depends on the environment can sometimes 9 File file = new File(fileName); not be fully covered simply by generating sequences of calls to a 10 if(!file.exists()) 11 return false; class under test, for example when execution of a branch depends 12 on the contents of a file. Second, even if code that is environment- 13 Scanner fromFile = new Scanner(new FileInputStream( dependent can be covered, the resulting tests may be unstable, i.e., file)); 14 String fileContent = fromFile.nextLine(); they would pass when first generated, but then may fail when exe- 15 fromFile.close(); cuted in a different environment. For example, tests on classes that 16 String date = DateFormat.getDateInstance(DateFormat. make use of the system time may have failing assertions if the tests SHORT).format(new Date()); 17 if(fileContent.equals(date)) are executed at a different time than when they were generated. -
David Keen Object Oriented Programming Mock Objects and Test Driven Design (TDD) the Text of This Essay Is My Own, Except Where
David Keen Object Oriented Programming Mock Objects and test driven design (TDD) The text of this essay is my own, except where explicitly indicated. I give my permission for this essay to be submitted to the JISC Plagiarism Detection Service. Test every work of intellect or faith And everything that your own hands have wrought William Butler Yeats Mock Objects are a relatively new tool in the object oriented programmer's toolkit. Developed by Tim Mackinnon, Steve Freeman, and Philip Craig and first presented at the conference “eXtreme Programming and Flexible Processes in Software Engineering – XP2000”, Mock Objects are a powerful aid to Unit Testing and Test Driven Development. Many programmers are familiar with unit testing. Basically, this involves writing tests for some or all of the classes and methods in a program. There are a number of unit testing frameworks such as the xUnit family, first designed by Kent Beck for SmallTalk but now extended to more than twenty- five different frameworks for languages such as C++, Perl, Java and PHP. The goal of unit testing is to isolate each method or function and, through the use of an automated testing framework, write tests than can be repeatedly run to verify the correctness of the code. Having complete coverage of your code with unit tests gives you the confidence that any change you make to existing code does not introduce new errors in other parts of your program. Unit testing is an important part of the eXtreme Programming methodology as well as other Agile methodologies such as Scrum. But Test Driven Development is more than just unit testing.