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

Get tests running on Python 3 #479

Closed
wants to merge 3 commits into from
Closed

Get tests running on Python 3 #479

wants to merge 3 commits into from

Conversation

singingwolfboy
Copy link
Contributor

This pull requests gets the unit tests to pass while running under Python 3. The code had a bunch of version checks scattered throughout to maintain compatibility -- I took those out and used the six library instead, which is designed for that. I also had to modify some of the number formatting in a few finicky tests; the formatting seemed pretty arbitrary, so I didn't think there would be any issue with me modifying it.

Once this is merged, can you enable Travis and Coveralls support by signing in with your "embolalia" Github account on their respective websites, and switching on the willie repo for each?

@elad661
Copy link
Contributor

elad661 commented Mar 9, 2014

use six for compatibility

No.
Won't merge. Closed.

@elad661 elad661 closed this Mar 9, 2014
@singingwolfboy
Copy link
Contributor Author

@elad661 Why not?

@elad661
Copy link
Contributor

elad661 commented Mar 9, 2014

Because I don't think introducing that dependency is a good idea. It works now, without that. Growing a dependency on a third party library for no reason is a bad thing, especially when it doesn't simplify your code.

Not to mention you do the same thing again where you put unrelated stuff in a pull request and this makes it harder for anyone to review your code. I'm not accepting 093b869, and that's final.

@singingwolfboy
Copy link
Contributor Author

@elad661 Have you tried actually using willie, and its modules, under Python 3? It doesn't work now, because there are mistaken references to unicode and basestring. Many of them are aliased, but not all, and apparently those cases aren't being tested, either manually or via continuous integration. Furthermore, I'm not actually growing a new dependency: praw depends on six, and possibly other of willie's dependencies do, as well. six is one file, and it's most likely already on the user's system; what's the problem with depending on it?

Also, tell me what's unrelated in this pull request, and I'll put it out into a separate pull request. Everything I did here was for the express purpose of getting the unit tests to run and pass on Python 3.

@singingwolfboy
Copy link
Contributor Author

Also, I'm not adding this dependency "for no reason". It does simplify the code, by putting all the 2/3 compatibility in one location rather than making other developers try to figure out what's responsible for what. In addition, you have willie set up as a platform, where other developers can write additional modules that work with willie. By not including a compatibility library like six, you're setting yourself up for people to make modules that are incompatible with Python 3 (or possibly Python 2, depending on what they use to test). It's unrealistic to expect every developer to test every change on every possible supported configuration, particularly when you don't even have your unit tests running in a continuous integration environment on every possible supported configuration. six reduces the mental overhead of trying to maintain a compatible codebase.

@elad661
Copy link
Contributor

elad661 commented Mar 9, 2014

I did test willie with Python 3. I'm the one who ported it to python 3. It works. Only with 3.3, so don't bother to test with anything older - we depend on some things that are only present in 3.3 and 2.7.

Anyway, no, I won't use six. It just makes the code more complicated, especially since we want to easily STOP supporting Python 2 soon, instead of supporting two versions.

praw is an OPTIONAL dependency. You can remove it and willie will still work. If you put six in the core, six will no longer be optional.

I don't know why you claim this doesn't work, because it works extremely well here. Instead of making large, untested commits that introduce new dependencies (and most likely break both Python 2 and Python 3. I assume you didn't even bother to test it properly with messages that are not in English, for example), why don't you REPORT THE BUGS YOU ARE SEEING?

Commit 093b869 is unrelated to the rest of this pull request because it's about changing how we handle python 3 compatibility and has nothing to do with how the tests are run. If the tests fail after you make it stop complaining about enchant, then we can take a look at this, and see the appropriate solution.

I'm not going to merge commit 093b869. Also, your other commits probably won't work because @embolalia reverted your change to setup.py because dev-requirements was missing in the pypi tarball and broke install from tarball.

@embolalia
Copy link
Contributor

@singingwolfboy, as @elad661 said, if you have issues, report them. Contributions are appreciated, but if we don't know what you're trying to solve, we can't check that you are, in fact, solving it. He is also correct about six. We want to minimize external dependencies in the core, and six does not currently bring us anything. Many of the things it brings are irrelevant when you're working with only 2.7 and >3.3 (and we are). We should be using range instead of xrange, and tools.iteritems can almost certainly be replaced by dict.items anywhere we're using it. Other than that, the only thing I see six bringing here is a string type superclass, and I don't see that as a sufficient benefit over Elad's implementation to warrant the third party module.

So, as the project's BDFL: six is not to be used in the core. If module writers want to include it in their own stuff, that's fine.

@ari-koivula
Copy link
Contributor

All unit tests should pass now on python33 with d24c11e.

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

Successfully merging this pull request may close these issues.

4 participants