DEPENDENCY INJECTION
May 29, 2018 FLORIN OLARIU
ABOUT ME
•
22+ years experience in software development(mainly as Technical Lead/Architect)•
Started in Centric 6 years ago•
Current role: .NET Discipline Coordinator/Domain Architect in Centric•
Professor Collaborator - Alexandru Ioan Cuza University – Computer Scince Faculty• PhD -> Increasing security for online payments by using biometrical algorithms
• Introduction to .NET/Software engineering
TITLE PRESENTATION May 29, 2018
AGENDA
•
7 Deadly Developer Sins•
Dependency Injection Pattern Overview• Demo : .NET Core Sample
• Demo : Java Spring Sample
• Demo : Angular Sample
•
Unit testing• Short Story
• Sandro Mancuso -> About unit testing story
• Why Unit Testing?
• What Is A Unit Test?
• Unit Test Example
• Unit Test Pyramid
• Tips For Writing Great Unit Tests
• Testing Goals
• Demo : .NET Core sample
•
Suggestions/Materials•
Summary•
QuestionsMay 29, 2018 TITLE PRESENTATION
7 DEADLY DEVELOPER SINS
7 DEADLY DEVELOPER SINS
1.
Potential bugs7 DEADLY DEVELOPER SINS
1.
Potential bugs2.
Coding standard breach (or lack of)7 DEADLY DEVELOPER SINS
1.
Potential bugs2.
Coding standard breach (or lack of)3.
Duplications7 DEADLY DEVELOPER SINS
1.
Potential bugs2.
Coding standard breach (or lack of)3.
Duplications4.
Lack of unit tests7 DEADLY DEVELOPER SINS
1.
Potential bugs2.
Coding standard breach (or lack of)3.
Duplications4.
Lack of unit tests5.
Bad distribution of complexity7 DEADLY DEVELOPER SINS
1.
Potential bugs2.
Coding standard breach (or lack of)3.
Duplications4.
Lack of unit tests5.
Bad distribution of complexity6.
Spaghetti design7 DEADLY DEVELOPER SINS
1.
Potential bugs2.
Coding standard breach (or lack of)3.
Duplications4.
Lack of unit tests5.
Bad distribution of complexity6.
Spaghetti design7.
Not enough or too many commentsDEPENDENCY INJECTION PATTERN OVERVIEW
May 29, 2018 TITLE PRESENTATION
DEPENDENCY INJECTION PATTERN OVERVIEW
“Dependency injection (DI) is a technique for achieving loose coupling between objects and their collaborators, or
dependencies. Rather than directly instantiating collaborators, or using static references, the objects a class needs in order to
perform its actions are provided to the class in some fashion.
Most often, classes will declare their dependencies via their constructor, allowing them to follow the Explicit Dependencies Principle. This approach is known as "constructor injection". “ Source - https://docs.microsoft.com/en-
us/aspnet/core/fundamentals/dependency- injection?view=aspnetcore-2.0
May 29, 2018 TITLE PRESENTATION
DEPENDENCY INJECTION PATTERN OVERVIEW
“Every Java-based application has a few objects that work together to present what the end-user sees as a working application. When writing a complex Java application,
application classes should be as independent as possible of other Java classes to increase the possibility to reuse these classes and to test them independently of other classes while unit testing. Dependency Injection (or sometime called wiring) helps in gluing these classes together and at the same time keeping them independent.”
Source -
https://www.tutorialspoint.com/spring/spring_dependency_injecti on.htm
May 29, 2018 TITLE PRESENTATION
DEPENDENCY INJECTION PATTERN OVERVIEW
“Dependency injection is an important application design pattern. It's used so widely that almost everyone just calls it DI.
Angular has its own dependency injection framework, and you really can't build an Angular application without it.
This page covers what DI is and why it's useful”
“Dependency Injection (DI) is a way to create objects
that depend upon other objects. A Dependency Injection system supplies the dependent objects (called the dependencies) when it creates an instance of an object.”
Source - https://angular.io/guide/dependency-injection
May 29, 2018 TITLE PRESENTATION
DEPENDENCY INJECTION PATTERN OVERVIEW
“In software engineering, dependency injection is a technique whereby one object (or static method) supplies the dependencies of another object. A dependency is an object that can be used (a service)”
Source - https://en.wikipedia.org/wiki/Dependency_injection
May 29, 2018 TITLE PRESENTATION
DI - .NET CORE SAMPLE
May 29, 2018 TITLE PRESENTATION
DI - JAVA SAMPLE
May 29, 2018 TITLE PRESENTATION
DI – ANGULAR SAMPLE
•
https://stackblitz.com/angular/poxbnrrxyre?file=src%2Fapp%2 Fuser.service.tsMay 29, 2018 TITLE PRESENTATION
SHORT STORY
SHORT STORY
•
Cameron Purdy, Programmed in assembly, C, C++, Java, C#, etc.– Answered Jun 12, 2014 · Upvoted by Jeff Nelson, Invented Chromebook, #Xoogler
SHORT STORY
•
“It's simple: Writing unit tests sucks. I personally (and absolutely) hate writing unit tests for code that I havewritten. I would rather go to the dentist than write unit tests.
Maybe even the proctologist.”
SHORT STORY
•
“On the other hand:”– “Even though I only started writing unit tests a few years ago, now I always write unit tests for software components that I am building.”
SHORT STORY
•
“On the other hand:”– “Even though I only started writing unit tests a few years ago, now I always write unit tests for software components that I am building.
– I have never regretted the time spent writing unit tests. Having unit tests is hugely valuable. Not just for finding bugs in the software, but for insulating against later breaking changes as well!”
SHORT STORY
•
“On the other hand:”– “Even though I only started writing unit tests a few years ago, now I always write unit tests for software components that I am building.
– I have never regretted the time spent writing unit tests. Having unit tests is hugely valuable. Not just for finding bugs in the software, but for insulating against later breaking changes as well!
– I love finding a few bugs while writing unit tests. Why "a few"? Well, if I never found any bugs in my code with unit tests, I would consider them a waste of time. If I found too many bugs in my code with unit tests, I would be forced to consider a change of careers.”
SHORT STORY
• “On the other hand:”
– “Even though I only started writing unit tests a few years ago, now I always write unit tests for software components that I am building.
– I have never regretted the time spent writing unit tests. Having unit tests is hugely valuable.
Not just for finding bugs in the software, but for insulating against later breaking changes as well!
– I love finding a few bugs while writing unit tests. Why "a few"? Well, if I never found any bugs in my code with unit tests, I would consider them a waste of time. If I found too many bugs in my code with unit tests, I would be forced to consider a change of careers.
– When a developer chooses to not write unit tests, they are telling their team-mates and those who depend on their software that this one developer's time is far more valuable than anyone else's time. Why? Because unit tests are an efficient investment, so not writing them means that other people's time is far,far less valuable than one's own time.”
SHORT STORY
• “On the other hand:”
– “Even though I only started writing unit tests a few years ago, now I always write unit tests for software components that I am building.
– I have never regretted the time spent writing unit tests. Having unit tests is hugely valuable.
Not just for finding bugs in the software, but for insulating against later breaking changes as well!
– I love finding a few bugs while writing unit tests. Why "a few"? Well, if I never found any bugs in my code with unit tests, I would consider them a waste of time. If I found too many bugs in my code with unit tests, I would be forced to consider a change of careers.
– When a developer chooses to not write unit tests, they are telling their team-mates and those who depend on their software that this one developer's time is far more valuable than anyone else's time. Why? Because unit tests are an efficient investment, so not writing them means that other people's time is far,far less valuable than one's own time.
• All that said, I still hate writing unit tests.”
SANDRO MANCUSO -> ABOUT UNIT TESTING
STORY
SANDRO MANCUSO -> ABOUT UNIT TESTING STORY
“At that point I could not keep quiet anymore.
“Now that you know what the problem is, why don’t you write some unit tests around it?”
I really wanted to ask why he didn’t write the tests before his changes in the first place but I thought he probably wouldn’t take that well.
“What I’m doing is important and needs to be done quickly,” he said.
“I don’t have time to write tests.”
Then he deployed the new version of the application into the testing
environment again (note that no one else could use the testing environment while he was doing his tests), played an XML message into the inbound queue, and started looking at the logs again. That went on for another two days until the problem was actually fixed.”
– Mancuso, Sandro. The Software Craftsman: Professionalism, Pragmatism, Pride (Robert C. Martin Series) (p. 82). Pearson Education. Kindle Edition.
WHY UNIT TESTING?
WHY UNIT TESTING?
WHY UNIT TESTING?
WHY UNIT TESTING?
•
BenefitsWHY UNIT TESTING?
•
Benefits• Find defects early
WHY UNIT TESTING?
•
Benefits• Find defects early
• Prevent regressions
WHY UNIT TESTING?
•
Benefits• Find defects early
• Prevent regressions
• Provide living documentation (source code)
WHY UNIT TESTING?
•
Benefits• Find defects early
• Prevent regressions
• Provide living documentation (source code)
• Automate testing efforts
WHAT IS A UNIT TEST?
WHAT IS A UNIT TEST?
•
Definition 1WHAT IS A UNIT TEST?
•
Definition 1•
“A unit test is a piece of code (usually a method) that invoke another piece of code and checks the correctness of some assumptions afterwards.”– Art of Unit testing
WHAT IS A UNIT TEST?
•
Definition 2WHAT IS A UNIT TEST?
•
Definition 2WHAT IS A UNIT TEST?
•
Definition 2•
Essentially, a unit test is a method that instantiates a small portion of our application and verifies its behaviorindependently from other parts.
UNIT TEST EXAMPLE
UNIT TEST EXAMPLE
UNIT TESTING PYRAMID
UNIT TESTING PYRAMID
TIPS FOR WRITING GREAT UNIT TESTS
TIPS FOR WRITING GREAT UNIT TESTS
•
Make each test independent to all the othersTIPS FOR WRITING GREAT UNIT TESTS
•
Make each test independent to all the others•
Any given behavior should be specified in one and only one testTIPS FOR WRITING GREAT UNIT TESTS
•
Make each test independent to all the others•
Any given behavior should be specified in one and only one•
testMock out all external services and stateTIPS FOR WRITING GREAT UNIT TESTS
•
Make each test independent to all the others•
Any given behavior should be specified in one and only one•
testMock out all external services and state•
“Any unit tests are better than none”TESTING GOALS
TESTING GOALS
Goal Strongest technique
TESTING GOALS
Goal Strongest technique
Finding bugs (things that don’t work as you want them to)
TESTING GOALS
Goal Strongest technique
Finding bugs (things that don’t work as you want them to)
Manual testing (sometimes also automated integration tests)
TESTING GOALS
Goal Strongest technique
Finding bugs (things that don’t work as you want them to)
Manual testing (sometimes also automated integration tests)
Detecting regressions (things that used to work but have unexpectedly stopped working)
TESTING GOALS
Goal Strongest technique
Finding bugs (things that don’t work as you want them to)
Manual testing (sometimes also automated integration tests)
Detecting regressions (things that used to work but have unexpectedly stopped working)
Automated integration tests (sometimes also manual testing, though time-consuming)
TESTING GOALS
Goal Strongest technique
Finding bugs (things that don’t work as you want them to)
Manual testing (sometimes also automated integration tests)
Detecting regressions (things that used to work but have unexpectedly stopped working)
Automated integration tests (sometimes also manual testing, though time-consuming) Designing software components robustly
TESTING GOALS
Goal Strongest technique
Finding bugs (things that don’t work as you want them to)
Manual testing (sometimes also automated integration tests)
Detecting regressions (things that used to work but have unexpectedly stopped working)
Automated integration tests (sometimes also manual testing, though time-consuming) Designing software components robustly Unit testing (within the TDD process)
SUGGESTIONS/MATERIALS
•
https://www.martinfowler.com/articles/injection.html•
https://livebook.manning.com/#!/book/the-art-of-unit-testing- second-edition/about-this-book/1•
https://www.amazon.com/Software-Craftsman-Professionalism-Pragmatism-Robert/dp/0134052501
May 29, 2018 TITLE PRESENTATION
ONE MORE THING…
ONE MORE THING…
“The difference between a bad programmer and a good
programmer is understanding. That is, bad programmers don’t understand what they are doing and good programmers do. — Max Kanat-Alexander”
― Steve Fenton, Pro Typescript: Application-Scale JavaScript Development
ONE MORE THING…
https://www.reddit.com/r/programming/comments/8cwa4o/depen dency_injection_is_a_25dollar_term_for_a/