Hacker News new | past | comments | ask | show | jobs | submit login

I'm confused by this line of reasoning.

The point of the black box is that you have clearly defined the expected input and output and don't care about the implementation details of the thing sitting inside the box.

You can test both what you pass in to the black box and what you get out of it. And it's incredibly useful and important to do so. If you aren't testing third party libraries (or other dependencies) in this way, you're opening yourself up to a lot of unnecessary risk.

Those assumptions about your expected output are always there, whether you define and test them or not. So if for some reason the library changes its output unexpectedly and you aren't explicitly testing your assumptions, it can easily happen that you won't find out until it manifests in a production bug.




> I'm confused by this line of reasoning.

That's because you haven't read the discussion. Why would you expect anything else? Your comment straight up reiterates what was already said. For example,

"The value proposition of testing is that it documents the user interface in a way that is independent of implementation, allowing you to continue to iterate on the implementation while having assurances that, no matter what you do under the hood, the user experience does not deviate from what is documented."

Explicitly testing third-party code introduces testing of implementation details. It is impossible to explicitly test another codebase without knowing of its existence. But it is not an area of concern for a first-party application to worry about. The third-party should already have those tests in the third-party codebase.


If a library changes its output unexpectedly, then either:

- It’s a local library so the tests covering your code should fail

- It’s changed in a way you didn’t anticipate so why would testing it directly fail when your prior test didn’t?

- Your end user monitoring should light up like a Christmas tree




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: