Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Proposal] Change testing framework back to PHPUnit #158

Open
seyfer opened this issue Nov 1, 2017 · 1 comment
Open

[Proposal] Change testing framework back to PHPUnit #158

seyfer opened this issue Nov 1, 2017 · 1 comment

Comments

@seyfer
Copy link
Collaborator

seyfer commented Nov 1, 2017

In my opinion use of Autom test framework doesn't add any benefit to the library and even creates some inconvenience. Why?
Because PHPUnit is de facto standard for testing in PHP world. And most of the developers know PHPUnit and only a few enthusiasts know Atoum.
This leads to a situation when some contributor wants to add some code to the library, he is much less likely to write a test with his pull request. Because most of the potential contributors don't know Atoum, it adds unnecessary learning curvy and actually prevents people from writing tests with their contributions.

To make my point stronger, I will provide a link with libraries popularity and activity comparison.
https://php.libhunt.com/project/atoum/vs/phpunit
And here is a story about the negative experience with Atoum and returning to PHPUnit
http://technosophos.com/2012/01/25/atoum-different-unit-testing-framework-php.html

I would like to read thoughts from other contributors and from the author @Ph3nol.
If everyone agrees, I would start a new branch for a migration process to PHPUnit.

@btry
Copy link

btry commented Oct 16, 2018

Hi

The story you shared is not very relevant. I use Atoum for some projects, and have sometimes race conditions between tests like the author described.

The author missed to tell that Atoum is designed to run tests in a test class in parallel, by running several PHP processes. Maybe he was not aware of the available solutions, or maybe they were not implemented at time of writing (2012). If you have some race conditions, I think this is interesting to know because this might be an opportunity to rewrite some parts of the project or its tests in a better way. If for some reason you cannot avoid such race condition you can:

  • tell Atoum to run one test at a time with the argument -mcn 1
  • run the annotation @engine inline on a test class or a test method to not run in a separate process (and de-facto run those annotated tests one by one)

I switched from PHPUnit to Atoum and I found tests really more easy to write mostly because in Atoum there is no need to mess with static methods to setup the test class or a test method.

You may have a look on this feedback:

https://glpi-project.org/glpi-now-uses-atoum-for-its-unit-tests-2/

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants