It's fine. Yes, in an ideal world, we'd verify that the id
we passed into the PeopleRepository.Get()
method is the same one that's getting passed to the client.Get()
method, but that's also getting down into testing the internal implementation of the method. What you really care about here is that when the Person
isn't found, a specific exception is thrown, so in this particular case it's fine.
Remember, we want to tests for specific results, not the internal implementation.
I'm going to quote Jon Skeet's comment to a related SO question Jon Skeet's comment to a related SO question.
I would test that the usage of those functions do the right thing, rather than testing that the exact same function is used. – Jon Skeet Oct 8 '12 at 9:33
It's fine. Yes, in an ideal world, we'd verify that the id
we passed into the PeopleRepository.Get()
method is the same one that's getting passed to the client.Get()
method, but that's also getting down into testing the internal implementation of the method. What you really care about here is that when the Person
isn't found, a specific exception is thrown, so in this particular case it's fine.
Remember, we want to tests for specific results, not the internal implementation.
I'm going to quote Jon Skeet's comment to a related SO question.
I would test that the usage of those functions do the right thing, rather than testing that the exact same function is used. – Jon Skeet Oct 8 '12 at 9:33
It's fine. Yes, in an ideal world, we'd verify that the id
we passed into the PeopleRepository.Get()
method is the same one that's getting passed to the client.Get()
method, but that's also getting down into testing the internal implementation of the method. What you really care about here is that when the Person
isn't found, a specific exception is thrown, so in this particular case it's fine.
Remember, we want to tests for specific results, not the internal implementation.
I'm going to quote Jon Skeet's comment to a related SO question.
I would test that the usage of those functions do the right thing, rather than testing that the exact same function is used. – Jon Skeet Oct 8 '12 at 9:33
It's fine. Yes, in an ideal world, we'd verify that the id
we passed into the PeopleRepository.Get()
method is the same one that's getting passed to the client.Get()
method, but that's also getting down into testing the internal implementation of the method. What you really care about here is that when the Person
isn't found, a specific exception is thrown, so in this particular case it's fine.
Remember, we want to tests for specific results, not the internal implementation.
I'm going to quote Jon Skeet's comment to a related SO question.
I would test that the usage of those functions do the right thing, rather than testing that the exact same function is used. – Jon Skeet Oct 8 '12 at 9:33