SlideShare a Scribd company logo
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

What's hot

Secure code
Secure codeSecure code
Secure code
ddeogun
 
Web Application Security 101
Web Application Security 101Web Application Security 101
Web Application Security 101
Jannis Kirschner
 
Web application security
Web application securityWeb application security
Web application security
Kapil Sharma
 
Secure coding-guidelines
Secure coding-guidelinesSecure coding-guidelines
Secure coding-guidelines
Trupti Shiralkar, CISSP
 
OWASP Secure Coding Practices - Quick Reference Guide
OWASP Secure Coding Practices - Quick Reference GuideOWASP Secure Coding Practices - Quick Reference Guide
OWASP Secure Coding Practices - Quick Reference Guide
Ludovic Petit
 
Owasp Top 10 - Owasp Pune Chapter - January 2008
Owasp Top 10 - Owasp Pune Chapter - January 2008Owasp Top 10 - Owasp Pune Chapter - January 2008
Owasp Top 10 - Owasp Pune Chapter - January 2008
abhijitapatil
 
Hack through Injections
Hack through InjectionsHack through Injections
Hack through Injections
Nazar Tymoshyk, CEH, Ph.D.
 
Practice of AppSec .NET
Practice of AppSec .NETPractice of AppSec .NET
Practice of AppSec .NET
Mikhail Shcherbakov
 
Secure Coding in C/C++
Secure Coding in C/C++Secure Coding in C/C++
Secure Coding in C/C++
Dan-Claudiu Dragoș
 
Security for developers
Security for developersSecurity for developers
Security for developers
Abdelrhman Shawky
 
Secure programming with php
Secure programming with phpSecure programming with php
Secure programming with php
Mohmad Feroz
 
Neoito — Secure coding practices
Neoito — Secure coding practicesNeoito — Secure coding practices
Neoito — Secure coding practices
Neoito
 
Session3 data-validation-sql injection
Session3 data-validation-sql injectionSession3 data-validation-sql injection
Session3 data-validation-sql injection
zakieh alizadeh
 
Hackers Paradise SQL Injection Attacks
Hackers Paradise SQL Injection AttacksHackers Paradise SQL Injection Attacks
Hackers Paradise SQL Injection Attacks
amiable_indian
 
Static analysis for security
Static analysis for securityStatic analysis for security
Static analysis for security
Fadi Abdulwahab
 
SecureWV: Exploiting Web APIs
SecureWV: Exploiting Web APIsSecureWV: Exploiting Web APIs
SecureWV: Exploiting Web APIs
ThreatReel Podcast
 
香港六合彩
香港六合彩香港六合彩
香港六合彩
baoyin
 
Penetration testing web application web application (in) security
Penetration testing web application web application (in) securityPenetration testing web application web application (in) security
Penetration testing web application web application (in) security
Nahidul Kibria
 
CONHESI 2021 - Exploiting Web APIs
CONHESI 2021 - Exploiting Web APIsCONHESI 2021 - Exploiting Web APIs
CONHESI 2021 - Exploiting Web APIs
ThreatReel Podcast
 

What's hot (19)

Secure code
Secure codeSecure code
Secure code
 
Web Application Security 101
Web Application Security 101Web Application Security 101
Web Application Security 101
 
Web application security
Web application securityWeb application security
Web application security
 
Secure coding-guidelines
Secure coding-guidelinesSecure coding-guidelines
Secure coding-guidelines
 
OWASP Secure Coding Practices - Quick Reference Guide
OWASP Secure Coding Practices - Quick Reference GuideOWASP Secure Coding Practices - Quick Reference Guide
OWASP Secure Coding Practices - Quick Reference Guide
 
Owasp Top 10 - Owasp Pune Chapter - January 2008
Owasp Top 10 - Owasp Pune Chapter - January 2008Owasp Top 10 - Owasp Pune Chapter - January 2008
Owasp Top 10 - Owasp Pune Chapter - January 2008
 
Hack through Injections
Hack through InjectionsHack through Injections
Hack through Injections
 
Practice of AppSec .NET
Practice of AppSec .NETPractice of AppSec .NET
Practice of AppSec .NET
 
Secure Coding in C/C++
Secure Coding in C/C++Secure Coding in C/C++
Secure Coding in C/C++
 
Security for developers
Security for developersSecurity for developers
Security for developers
 
Secure programming with php
Secure programming with phpSecure programming with php
Secure programming with php
 
Neoito — Secure coding practices
Neoito — Secure coding practicesNeoito — Secure coding practices
Neoito — Secure coding practices
 
Session3 data-validation-sql injection
Session3 data-validation-sql injectionSession3 data-validation-sql injection
Session3 data-validation-sql injection
 
Hackers Paradise SQL Injection Attacks
Hackers Paradise SQL Injection AttacksHackers Paradise SQL Injection Attacks
Hackers Paradise SQL Injection Attacks
 
Static analysis for security
Static analysis for securityStatic analysis for security
Static analysis for security
 
SecureWV: Exploiting Web APIs
SecureWV: Exploiting Web APIsSecureWV: Exploiting Web APIs
SecureWV: Exploiting Web APIs
 
香港六合彩
香港六合彩香港六合彩
香港六合彩
 
Penetration testing web application web application (in) security
Penetration testing web application web application (in) securityPenetration testing web application web application (in) security
Penetration testing web application web application (in) security
 
CONHESI 2021 - Exploiting Web APIs
CONHESI 2021 - Exploiting Web APIsCONHESI 2021 - Exploiting Web APIs
CONHESI 2021 - Exploiting Web APIs
 

Similar to Microsoft Fakes, Unit Testing the (almost) Untestable Code

Automated Software Testing Framework Training by Quontra Solutions
Automated Software Testing Framework Training by Quontra SolutionsAutomated Software Testing Framework Training by Quontra Solutions
Automated Software Testing Framework Training by Quontra Solutions
Quontra Solutions
 
Unit Testing
Unit TestingUnit Testing
Unit Testing
Sergey Podolsky
 
Unit tests and TDD
Unit tests and TDDUnit tests and TDD
Unit tests and TDD
Roman Okolovich
 
Test Driven Development
Test Driven DevelopmentTest Driven Development
Test Driven Development
Sergey Aganezov
 
Unit Testing Fundamentals
Unit Testing FundamentalsUnit Testing Fundamentals
Unit Testing FundamentalsRichard Paul
 
Testing Angular
Testing AngularTesting Angular
Testing Angular
Lilia Sfaxi
 
Testing Frameworks
Testing FrameworksTesting Frameworks
Testing Frameworks
Moataz Nabil
 
Unit tests & TDD
Unit tests & TDDUnit tests & TDD
Unit tests & TDD
Dror Helper
 
Devday2016 real unittestingwithmockframework-phatvu
Devday2016 real unittestingwithmockframework-phatvuDevday2016 real unittestingwithmockframework-phatvu
Devday2016 real unittestingwithmockframework-phatvu
Phat VU
 
Advanced Coded UI Testing
Advanced Coded UI TestingAdvanced Coded UI Testing
Advanced Coded UI Testing
Shai Raiten
 
Agile Mumbai 2020 Conference | How to get the best ROI on Your Test Automati...
Agile Mumbai 2020 Conference |  How to get the best ROI on Your Test Automati...Agile Mumbai 2020 Conference |  How to get the best ROI on Your Test Automati...
Agile Mumbai 2020 Conference | How to get the best ROI on Your Test Automati...
AgileNetwork
 
Binary Studio Academy: .NET Code Testing
Binary Studio Academy: .NET Code TestingBinary Studio Academy: .NET Code Testing
Binary Studio Academy: .NET Code Testing
Binary Studio
 
Clean Code in Test Automation Differentiating Between the Good and the Bad
Clean Code in Test Automation  Differentiating Between the Good and the BadClean Code in Test Automation  Differentiating Between the Good and the Bad
Clean Code in Test Automation Differentiating Between the Good and the Bad
Knoldus Inc.
 
Unit Testing Full@
Unit Testing Full@Unit Testing Full@
Unit Testing Full@Alex Borsuk
 
[DevDay 2016] Real Unit Testing with mocking framework - Speaker: Phat Vu – S...
[DevDay 2016] Real Unit Testing with mocking framework - Speaker: Phat Vu – S...[DevDay 2016] Real Unit Testing with mocking framework - Speaker: Phat Vu – S...
[DevDay 2016] Real Unit Testing with mocking framework - Speaker: Phat Vu – S...
DevDay.org
 
Tools for Software Testing
Tools for Software TestingTools for Software Testing
Tools for Software Testing
Mohammed Moishin
 
An Introduction to Unit Testing
An Introduction to Unit TestingAn Introduction to Unit Testing
An Introduction to Unit Testing
Sahar Nofal
 
AspectMock
AspectMockAspectMock
AspectMock
Bryce Embry
 
Beginners overview of automated testing with Rspec
Beginners overview of automated testing with RspecBeginners overview of automated testing with Rspec
Beginners overview of automated testing with Rspec
jeffrey1ross
 

Similar to Microsoft Fakes, Unit Testing the (almost) Untestable Code (20)

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

Recently uploaded

How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?
How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?
How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?
XfilesPro
 
First Steps with Globus Compute Multi-User Endpoints
First Steps with Globus Compute Multi-User EndpointsFirst Steps with Globus Compute Multi-User Endpoints
First Steps with Globus Compute Multi-User Endpoints
Globus
 
Lecture 1 Introduction to games development
Lecture 1 Introduction to games developmentLecture 1 Introduction to games development
Lecture 1 Introduction to games development
abdulrafaychaudhry
 
De mooiste recreatieve routes ontdekken met RouteYou en FME
De mooiste recreatieve routes ontdekken met RouteYou en FMEDe mooiste recreatieve routes ontdekken met RouteYou en FME
De mooiste recreatieve routes ontdekken met RouteYou en FME
Jelle | Nordend
 
BoxLang: Review our Visionary Licenses of 2024
BoxLang: Review our Visionary Licenses of 2024BoxLang: Review our Visionary Licenses of 2024
BoxLang: Review our Visionary Licenses of 2024
Ortus Solutions, Corp
 
Globus Connect Server Deep Dive - GlobusWorld 2024
Globus Connect Server Deep Dive - GlobusWorld 2024Globus Connect Server Deep Dive - GlobusWorld 2024
Globus Connect Server Deep Dive - GlobusWorld 2024
Globus
 
In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...
In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...
In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...
Juraj Vysvader
 
2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx
Georgi Kodinov
 
Prosigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology SolutionsProsigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology Solutions
Prosigns
 
Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...
Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...
Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...
Anthony Dahanne
 
Globus Compute Introduction - GlobusWorld 2024
Globus Compute Introduction - GlobusWorld 2024Globus Compute Introduction - GlobusWorld 2024
Globus Compute Introduction - GlobusWorld 2024
Globus
 
Cyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdfCyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdf
Cyanic lab
 
Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...
Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...
Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...
Globus
 
Developing Distributed High-performance Computing Capabilities of an Open Sci...
Developing Distributed High-performance Computing Capabilities of an Open Sci...Developing Distributed High-performance Computing Capabilities of an Open Sci...
Developing Distributed High-performance Computing Capabilities of an Open Sci...
Globus
 
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdfDominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
AMB-Review
 
Quarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden ExtensionsQuarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden Extensions
Max Andersen
 
GlobusWorld 2024 Opening Keynote session
GlobusWorld 2024 Opening Keynote sessionGlobusWorld 2024 Opening Keynote session
GlobusWorld 2024 Opening Keynote session
Globus
 
Designing for Privacy in Amazon Web Services
Designing for Privacy in Amazon Web ServicesDesigning for Privacy in Amazon Web Services
Designing for Privacy in Amazon Web Services
KrzysztofKkol1
 
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.ILBeyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Natan Silnitsky
 
Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...
Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...
Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...
Shahin Sheidaei
 

Recently uploaded (20)

How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?
How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?
How Does XfilesPro Ensure Security While Sharing Documents in Salesforce?
 
First Steps with Globus Compute Multi-User Endpoints
First Steps with Globus Compute Multi-User EndpointsFirst Steps with Globus Compute Multi-User Endpoints
First Steps with Globus Compute Multi-User Endpoints
 
Lecture 1 Introduction to games development
Lecture 1 Introduction to games developmentLecture 1 Introduction to games development
Lecture 1 Introduction to games development
 
De mooiste recreatieve routes ontdekken met RouteYou en FME
De mooiste recreatieve routes ontdekken met RouteYou en FMEDe mooiste recreatieve routes ontdekken met RouteYou en FME
De mooiste recreatieve routes ontdekken met RouteYou en FME
 
BoxLang: Review our Visionary Licenses of 2024
BoxLang: Review our Visionary Licenses of 2024BoxLang: Review our Visionary Licenses of 2024
BoxLang: Review our Visionary Licenses of 2024
 
Globus Connect Server Deep Dive - GlobusWorld 2024
Globus Connect Server Deep Dive - GlobusWorld 2024Globus Connect Server Deep Dive - GlobusWorld 2024
Globus Connect Server Deep Dive - GlobusWorld 2024
 
In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...
In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...
In 2015, I used to write extensions for Joomla, WordPress, phpBB3, etc and I ...
 
2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx2024 RoOUG Security model for the cloud.pptx
2024 RoOUG Security model for the cloud.pptx
 
Prosigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology SolutionsProsigns: Transforming Business with Tailored Technology Solutions
Prosigns: Transforming Business with Tailored Technology Solutions
 
Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...
Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...
Paketo Buildpacks : la meilleure façon de construire des images OCI? DevopsDa...
 
Globus Compute Introduction - GlobusWorld 2024
Globus Compute Introduction - GlobusWorld 2024Globus Compute Introduction - GlobusWorld 2024
Globus Compute Introduction - GlobusWorld 2024
 
Cyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdfCyaniclab : Software Development Agency Portfolio.pdf
Cyaniclab : Software Development Agency Portfolio.pdf
 
Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...
Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...
Exploring Innovations in Data Repository Solutions - Insights from the U.S. G...
 
Developing Distributed High-performance Computing Capabilities of an Open Sci...
Developing Distributed High-performance Computing Capabilities of an Open Sci...Developing Distributed High-performance Computing Capabilities of an Open Sci...
Developing Distributed High-performance Computing Capabilities of an Open Sci...
 
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdfDominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
Dominate Social Media with TubeTrivia AI’s Addictive Quiz Videos.pdf
 
Quarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden ExtensionsQuarkus Hidden and Forbidden Extensions
Quarkus Hidden and Forbidden Extensions
 
GlobusWorld 2024 Opening Keynote session
GlobusWorld 2024 Opening Keynote sessionGlobusWorld 2024 Opening Keynote session
GlobusWorld 2024 Opening Keynote session
 
Designing for Privacy in Amazon Web Services
Designing for Privacy in Amazon Web ServicesDesigning for Privacy in Amazon Web Services
Designing for Privacy in Amazon Web Services
 
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.ILBeyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
Beyond Event Sourcing - Embracing CRUD for Wix Platform - Java.IL
 
Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...
Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...
Gamify Your Mind; The Secret Sauce to Delivering Success, Continuously Improv...
 

Microsoft Fakes, Unit Testing the (almost) Untestable Code

  • 1.
  • 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

  1. 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.