SlideShare a Scribd company logo
Unit Tests with Microsoft Fakes
Microsoft Fakes
Aleksandar Bozinovski
Technical Lead, Seavus
Unit Testing the (almost) Untestable Code
Agenda
Testing in software
Unit testing
• Why unit tests
• Unit tests conventions
• Dependencies, Coupling
Microsoft Fakes
• How does it help
• How does it work
• Stubs
• Shims
• How Do I choose
Q&A
Unit
Testing
Page 5
Strategy Description Visual Studio Tooling
Exploratory
Test
Tester tries to think of possible scenarios not covered by other test strategies and
tests. Useful when engaging users with the testing and observing their (expected)
usage of the system. There are no predefined tests.
Exploratory testing with Microsoft
test Manager (MTM)
Integration
Test
Testing different solution components working together as one. Visual Studio Unit Test features
Load Test Testing under load, in a controlled environment. Visual Studio Load Test Agent
Regression
Test
Regression testing ensures that the system still meets the quality bar after changes
such as bug fixes. Uses a mixture of unit tests and system tests.
Automated testing with MTM
Smoke Test Smoke testing is used to test a new feature or idea before committing the code
changes.
System Test Testing of the entire system against expected features and non-functional
requirements.
Visual Studio Lab Management
Unit Test A test of the smallest unit of code (method / class, and so on) that can be tested
in isolation from other units.
Visual Studio Test Explorer
Unit Test Frameworks
User
Acceptance
Test
Toward the end of the product cycles users are invited to perform acceptance
testing under real-world scenarios, typically based on test cases.
Automated testing with MTM
Testing types
Page 6
Testing types effort
Page 7
Unit testing?
• Unit testing is a software testing method by which individual units of
source code, are tested to determine whether they are fit for use.
• “Units of source code” are methods/functions. The unit test is simply
a method/function that calls another method and determines that
the later works correctly.
• How we can verify that our GetEmployeeById(int id) works correctly? Isolation, a
mechanism that will isolate the code under test, and resolve all dependencies
• Unit tests naming conventions:
• MethodName_StateUnderTest_ExpectedBehavior
• WithdrawMoney_InvalidAccount_ExceptionThrown
• MethodName_ExpectedBehavior_StateUnderTest
• Should_ExpectedBehavior_When_StateUnderTest
• Make sure the code works
• Refactor with confidence
• Support emerging design
• Reducing the cost of fixing bugs by fixing them earlier, rather than later
• Get a quick understanding of the quality of code
Page 8
Why Unit Tests?
Unit tests conventions
• Unit tests naming conventions (there are many)
• MethodName_StateUnderTest_ExpectedBehavior
• WithdrawMoney_InvalidAccount_ReturnsFalse()
• Login_InvalidCredentials_ReturnsErrorMessage()
• MethodName_ExpectedBehavior_StateUnderTest
• WithdrawMoney_ReturnsFalse_InvalidAccount ()
• The 3A of unit testing – Arrange, Act, Assert
• Arrange: Set up the object to be tested. We may need to surround the object with collaborators.
For testing purposes, those collaborators might be test objects (mocks, fakes, etc.) or the real
thing.
• Act: Act on the object (through some mutator). You may need to give it parameters (again,
possibly test objects).
• Assert: Make claims about the object, its collaborators, its parameters, and possibly (rarely!!)
global state.
Page 9
Demo
First unit test
Page 10
• In software engineering, coupling is the manner and degree of
interdependence between software modules. Much of unit tests is
solving dependencies and coupling.
• Practicing unit tests will improve code quality on the long run.
Some principles and patterns must be employed to improve
testability.
• Single responsibility principle (SRP)
• Open Closed Principle (OCP)
• Dependency Inversion Principle (DI)
• Don’t Repeat Yourself (DRY)
• You Aren’t Going to Need It (YAGNI)
Page 11
Dependencies, Coupling
Microsoft
Fakes
• Microsoft Fakes is a framework that enables us to isolate the code we are
testing by replacing dependencies of our code with stubs or shims.
• The Fakes Framework in Visual Studio 2012 is the next generation of Moles
& Stubs. (Read: migrate not upgrade)
• Available in VS 2012/2013 Ultimate
• Works with .Net framework 2.0 and Above
• Newest version available with VS 2015 Enterprise
Page 13
What is the Microsoft Fakes Framework?
• Allows us to quickly implement doubles to support testing in isolation
• Allows us to decouple from slow running dependencies like DB, file system,
message system.
• Decoupling allows us to write order independent unit tests
• Stage data in test methods, not in a DB.
• One unit test failure will not cause a chain reaction
• No need to reset a database to a golden state.
• Allows us to intercept calls to dependencies we do not control.
Page 14
How the Fakes framework helps
• In Microsoft Fakes, the developer must right-click the assembly
reference they wish to mock and select Add Fakes Assembly. This will
generate a new assembly that must be referenced to create the fake
objects.
Page 15
Generated code
Demo
Intro to Stubs
• Should you, or should you not, change the design of
existing code to make it more testable?
Page 17
Question - Code isolation
Demo
Membership Provider
• For every public type in the referenced assembly which are included
into shim-based faking via configuration, the Microsoft Fakes
mechanism generates a shim class. The type name is the same as the
original type, with "Shim" as a prefix.
Page 19
Shims (all instances)
• Shim methods can be injected per instance of an object.
In this example myClass1.MyMethod() will return 5 while
myClass2.MyMethod() will return 10;
Page 20
Shims (one instance)
• Shims must be used within a ShimsContext.Create() using statement.
• If need to execute original code a call to
ShimsContext.ExecuteWithoutShims must be placed inside the
shimmed method.
Page 21
Shims Context and Behavior
Demo
Log Aggregator
Demo
WPF Clock
• Stubs
• Helps if you’re interface-driven
• Creates default() implementations of an interface
• including properties & methods
• Shims
• <magic/>
• Substitute hard-coded types with
*something else* at runtime
Dae Page 24
Stubs and Shims
• Stubs
• If you’ve got interfaces already
• You’re building from scratch
• If you want to save yourself some typing
• You aren’t battling “sealed” and “static” keywords
• Shims
• Stuff is hopelessly stuck together
• Stuff is hopelessly non-testable
• You’re supporting legacy code
• You are Ninja
• Shims are not a long-term solution (except when there is no other
solution).
Page 25
Stubs and Shims
Thank you for your attention!
Copyright: © 2016 Seavus. All rights reserved. | www.seavus.com | www.career.seavus.com

More Related Content

PPTX
Background processing with hangfire
PDF
Agile Tools
PPTX
ASP.NET security vulnerabilities
PPTX
Hacker Proof web app using Functional tests
PPTX
Secure Coding 101 - OWASP University of Ottawa Workshop
PDF
Automated Security Testing
PPTX
Web automation with Selenium for software engineers
PDF
Security DevOps - Free pentesters' time to focus on high-hanging fruits // Ha...
Background processing with hangfire
Agile Tools
ASP.NET security vulnerabilities
Hacker Proof web app using Functional tests
Secure Coding 101 - OWASP University of Ottawa Workshop
Automated Security Testing
Web automation with Selenium for software engineers
Security DevOps - Free pentesters' time to focus on high-hanging fruits // Ha...

What's hot (20)

PPTX
Security Code Review 101
PDF
Breaking Dependencies to Allow Unit Testing
PPTX
Security testautomation
PPTX
Breaking Dependencies to Allow Unit Testing
PPTX
Cakephp vs. laravel
PPTX
Windows Azure Acid Test
PDF
Security DevOps - Staying secure in agile projects // OWASP AppSecEU 2015 - A...
PPT
Test Driven Development using QUnit
PPTX
Continuous Security Testing with Devops - OWASP EU 2014
PPTX
Server Side Template Injection by Mandeep Jadon
PDF
Javacro 2014 Spring Security 3 Speech
PPTX
SQLi for Security Champions
PDF
vodQA Pune (2019) - Browser automation using dev tools
PPTX
Security Model in .NET Framework
PPTX
Presentation
PPTX
Practice of AppSec .NET
PDF
Just Enough Threat Modeling
PDF
Zane lackey. security at scale. web application security in a continuous depl...
PPTX
Refactoring Legacy Web Forms for Test Automation
PDF
Web Application Security II - SQL Injection
Security Code Review 101
Breaking Dependencies to Allow Unit Testing
Security testautomation
Breaking Dependencies to Allow Unit Testing
Cakephp vs. laravel
Windows Azure Acid Test
Security DevOps - Staying secure in agile projects // OWASP AppSecEU 2015 - A...
Test Driven Development using QUnit
Continuous Security Testing with Devops - OWASP EU 2014
Server Side Template Injection by Mandeep Jadon
Javacro 2014 Spring Security 3 Speech
SQLi for Security Champions
vodQA Pune (2019) - Browser automation using dev tools
Security Model in .NET Framework
Presentation
Practice of AppSec .NET
Just Enough Threat Modeling
Zane lackey. security at scale. web application security in a continuous depl...
Refactoring Legacy Web Forms for Test Automation
Web Application Security II - SQL Injection
Ad

Viewers also liked (9)

DOCX
Journal social psychology
PPTX
Carbohydrates
PDF
9 Mehra and Jain JDT
PDF
Repowering America
PDF
Shipping to russia 1047
DOCX
CTB Resume
PDF
DAP AN CHI TIET DE THI MB
PPTX
Cardiovascular System
PPTX
How to Scale Lead Generation with Facebook, Instagram and Twitter Ads
Journal social psychology
Carbohydrates
9 Mehra and Jain JDT
Repowering America
Shipping to russia 1047
CTB Resume
DAP AN CHI TIET DE THI MB
Cardiovascular System
How to Scale Lead Generation with Facebook, Instagram and Twitter Ads
Ad

Similar to Unit Tests with Microsoft Fakes (20)

PPT
Automated Software Testing Framework Training by Quontra Solutions
PPTX
Unit Testing
PPTX
Unit tests and TDD
PPTX
Test Driven Development
PDF
Unit Testing Fundamentals
PDF
Testing Angular
PPT
Testing Frameworks
PPTX
Unit tests & TDD
PDF
Devday2016 real unittestingwithmockframework-phatvu
PPTX
Advanced Coded UI Testing
PDF
Agile Mumbai 2020 Conference | How to get the best ROI on Your Test Automati...
PPTX
Binary Studio Academy: .NET Code Testing
PPTX
NET Code Testing
PPTX
Clean Code in Test Automation Differentiating Between the Good and the Bad
PPTX
Unit Testing Full@
PDF
[DevDay 2016] Real Unit Testing with mocking framework - Speaker: Phat Vu – S...
PPTX
Tools for Software Testing
PPTX
An Introduction to Unit Testing
PPTX
AspectMock
PPTX
Beginners overview of automated testing with Rspec
Automated Software Testing Framework Training by Quontra Solutions
Unit Testing
Unit tests and TDD
Test Driven Development
Unit Testing Fundamentals
Testing Angular
Testing Frameworks
Unit tests & TDD
Devday2016 real unittestingwithmockframework-phatvu
Advanced Coded UI Testing
Agile Mumbai 2020 Conference | How to get the best ROI on Your Test Automati...
Binary Studio Academy: .NET Code Testing
NET Code Testing
Clean Code in Test Automation Differentiating Between the Good and the Bad
Unit Testing Full@
[DevDay 2016] Real Unit Testing with mocking framework - Speaker: Phat Vu – S...
Tools for Software Testing
An Introduction to Unit Testing
AspectMock
Beginners overview of automated testing with Rspec

Recently uploaded (20)

PDF
Digital Strategies for Manufacturing Companies
PDF
PTS Company Brochure 2025 (1).pdf.......
PPTX
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
PPTX
Embracing Complexity in Serverless! GOTO Serverless Bengaluru
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PPTX
ai tools demonstartion for schools and inter college
PPTX
CHAPTER 2 - PM Management and IT Context
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PDF
Design an Analysis of Algorithms I-SECS-1021-03
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PDF
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
PDF
Upgrade and Innovation Strategies for SAP ERP Customers
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
PDF
Nekopoi APK 2025 free lastest update
PPTX
Transform Your Business with a Software ERP System
PPTX
Introduction to Artificial Intelligence
Digital Strategies for Manufacturing Companies
PTS Company Brochure 2025 (1).pdf.......
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
Embracing Complexity in Serverless! GOTO Serverless Bengaluru
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
Wondershare Filmora 15 Crack With Activation Key [2025
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
How to Migrate SBCGlobal Email to Yahoo Easily
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
ai tools demonstartion for schools and inter college
CHAPTER 2 - PM Management and IT Context
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
Design an Analysis of Algorithms I-SECS-1021-03
How to Choose the Right IT Partner for Your Business in Malaysia
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
Upgrade and Innovation Strategies for SAP ERP Customers
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
Nekopoi APK 2025 free lastest update
Transform Your Business with a Software ERP System
Introduction to Artificial Intelligence

Unit Tests with Microsoft Fakes

  • 2. Microsoft Fakes Aleksandar Bozinovski Technical Lead, Seavus Unit Testing the (almost) Untestable Code
  • 3. Agenda Testing in software Unit testing • Why unit tests • Unit tests conventions • Dependencies, Coupling Microsoft Fakes • How does it help • How does it work • Stubs • Shims • How Do I choose Q&A
  • 5. Page 5 Strategy Description Visual Studio Tooling Exploratory Test Tester tries to think of possible scenarios not covered by other test strategies and tests. Useful when engaging users with the testing and observing their (expected) usage of the system. There are no predefined tests. Exploratory testing with Microsoft test Manager (MTM) Integration Test Testing different solution components working together as one. Visual Studio Unit Test features Load Test Testing under load, in a controlled environment. Visual Studio Load Test Agent Regression Test Regression testing ensures that the system still meets the quality bar after changes such as bug fixes. Uses a mixture of unit tests and system tests. Automated testing with MTM Smoke Test Smoke testing is used to test a new feature or idea before committing the code changes. System Test Testing of the entire system against expected features and non-functional requirements. Visual Studio Lab Management Unit Test A test of the smallest unit of code (method / class, and so on) that can be tested in isolation from other units. Visual Studio Test Explorer Unit Test Frameworks User Acceptance Test Toward the end of the product cycles users are invited to perform acceptance testing under real-world scenarios, typically based on test cases. Automated testing with MTM Testing types
  • 7. Page 7 Unit testing? • Unit testing is a software testing method by which individual units of source code, are tested to determine whether they are fit for use. • “Units of source code” are methods/functions. The unit test is simply a method/function that calls another method and determines that the later works correctly. • How we can verify that our GetEmployeeById(int id) works correctly? Isolation, a mechanism that will isolate the code under test, and resolve all dependencies • Unit tests naming conventions: • MethodName_StateUnderTest_ExpectedBehavior • WithdrawMoney_InvalidAccount_ExceptionThrown • MethodName_ExpectedBehavior_StateUnderTest • Should_ExpectedBehavior_When_StateUnderTest
  • 8. • Make sure the code works • Refactor with confidence • Support emerging design • Reducing the cost of fixing bugs by fixing them earlier, rather than later • Get a quick understanding of the quality of code Page 8 Why Unit Tests?
  • 9. Unit tests conventions • Unit tests naming conventions (there are many) • MethodName_StateUnderTest_ExpectedBehavior • WithdrawMoney_InvalidAccount_ReturnsFalse() • Login_InvalidCredentials_ReturnsErrorMessage() • MethodName_ExpectedBehavior_StateUnderTest • WithdrawMoney_ReturnsFalse_InvalidAccount () • The 3A of unit testing – Arrange, Act, Assert • Arrange: Set up the object to be tested. We may need to surround the object with collaborators. For testing purposes, those collaborators might be test objects (mocks, fakes, etc.) or the real thing. • Act: Act on the object (through some mutator). You may need to give it parameters (again, possibly test objects). • Assert: Make claims about the object, its collaborators, its parameters, and possibly (rarely!!) global state. Page 9
  • 11. • In software engineering, coupling is the manner and degree of interdependence between software modules. Much of unit tests is solving dependencies and coupling. • Practicing unit tests will improve code quality on the long run. Some principles and patterns must be employed to improve testability. • Single responsibility principle (SRP) • Open Closed Principle (OCP) • Dependency Inversion Principle (DI) • Don’t Repeat Yourself (DRY) • You Aren’t Going to Need It (YAGNI) Page 11 Dependencies, Coupling
  • 13. • Microsoft Fakes is a framework that enables us to isolate the code we are testing by replacing dependencies of our code with stubs or shims. • The Fakes Framework in Visual Studio 2012 is the next generation of Moles & Stubs. (Read: migrate not upgrade) • Available in VS 2012/2013 Ultimate • Works with .Net framework 2.0 and Above • Newest version available with VS 2015 Enterprise Page 13 What is the Microsoft Fakes Framework?
  • 14. • Allows us to quickly implement doubles to support testing in isolation • Allows us to decouple from slow running dependencies like DB, file system, message system. • Decoupling allows us to write order independent unit tests • Stage data in test methods, not in a DB. • One unit test failure will not cause a chain reaction • No need to reset a database to a golden state. • Allows us to intercept calls to dependencies we do not control. Page 14 How the Fakes framework helps
  • 15. • In Microsoft Fakes, the developer must right-click the assembly reference they wish to mock and select Add Fakes Assembly. This will generate a new assembly that must be referenced to create the fake objects. Page 15 Generated code
  • 17. • Should you, or should you not, change the design of existing code to make it more testable? Page 17 Question - Code isolation
  • 19. • For every public type in the referenced assembly which are included into shim-based faking via configuration, the Microsoft Fakes mechanism generates a shim class. The type name is the same as the original type, with "Shim" as a prefix. Page 19 Shims (all instances)
  • 20. • Shim methods can be injected per instance of an object. In this example myClass1.MyMethod() will return 5 while myClass2.MyMethod() will return 10; Page 20 Shims (one instance)
  • 21. • Shims must be used within a ShimsContext.Create() using statement. • If need to execute original code a call to ShimsContext.ExecuteWithoutShims must be placed inside the shimmed method. Page 21 Shims Context and Behavior
  • 24. • Stubs • Helps if you’re interface-driven • Creates default() implementations of an interface • including properties & methods • Shims • <magic/> • Substitute hard-coded types with *something else* at runtime Dae Page 24 Stubs and Shims
  • 25. • Stubs • If you’ve got interfaces already • You’re building from scratch • If you want to save yourself some typing • You aren’t battling “sealed” and “static” keywords • Shims • Stuff is hopelessly stuck together • Stuff is hopelessly non-testable • You’re supporting legacy code • You are Ninja • Shims are not a long-term solution (except when there is no other solution). Page 25 Stubs and Shims
  • 26. Thank you for your attention! Copyright: © 2016 Seavus. All rights reserved. | www.seavus.com | www.career.seavus.com

Editor's Notes

  • #12: MY Practical definitions SRP – designing classes so they do one thing well keeps the class simple. Simple classes are easier to test. Code smell large classes and large methods. OCP – Design classes to be resilient in the face of change. For example using abstract methods on base classes lets add behavior without changing existing code. Code smell frequently adding a case to a switch statement or If then Else If DI - high level classes are not working directly with low level classes, they are using interfaces as an abstract layer. Why – Easier to test in isolation! Code smell : “Newing up classes” DRY – Don’t repeat yourself – code and test it once reuse many times. Less code to write – less code to change (1 spot) YAGNI – Don’t write code until you need it. Remove unused code and corresponding tests – greatest refactor you do removes code.