It's almost been five weeks since my project started - FIVE
weeks! I have no idea where they went. All my days over the past few weeks have
kind of blurred together in my memory. As I started writing this blog post I
tried to count the number of weeks and tried to remember what I did each week.
So wait, it's been five weeks? "Hmm, let's think. I spent about one week getting
my hands wet with WCSAxes, then I spent about one week implementing a tricky
feature, and then one week writing a testing framework and then one week
working on smaller bugs and writing documentation. But that's only four weeks -
where did the fifth week go?" And then it hit me, I'd spent about two weeks
writing a testing framework. It took me a good ten minutes of sorting through my GitHub commit history to realize that.
It's strange how when you look back at things, every task seems like it shouldn't
have taken as long as it did.
Like I said, I've spent two weeks so far developing a testing framework for WCSAxes. So what does the testing framework entail? As I've explained in my earlier posts, WCSAxes is a framework for plotting astronomical images so ultimately we want to make sure it plots all those images correctly. If a developer makes changes to the code, then we want to make sure there's a way to test that the new code doesn't break things, like labels being added on top of each other in an image for instance. Matplotlib has an image comparison method that I decided to use in our tests. It compares images pixel by pixel and if the root mean square value of the difference is larger than a defined tolerance level (which we can set to whatever we want), then the test fails. I had to learn a lot more about the pytest unit testing framework that Astropy uses, along with learning more about fixtures and decorators to make these image unit tests a bit easier for users and developers to work with. Also I've realized that I hate decorators, I really do. Using them is simple and great but trying to write one? Not so much. I tried to make my own decorator for one task, failed and then decided to use a fixture instead. And hey, the fixture works just as good so I'm happy.
More interesting things I've learned about? Travis. Ah yes, I love
Travis, but it gave me some serious headaches for a couple of days. There were
some image tests that I wrote that passed easily on my machine but would fail
on the Travis CI build and I had no idea why. Eventually I took out some
semi-obscure font and style settings taken from Matplotlib which Travis and my
machine were interpreting differently (that's the only way I can describe it) and got the image tests to pass.
I haven't adhered very strictly to the proposed project
timeline from my application. This week I worked on cleaning up code from my pull requests, getting them merged and updating the documentation. Things have been pretty fluid and I've been
getting things done on more of a priority basis. We're almost at the point
where we can release the first version of WCSAxes except I just need to finish
up the documentation and fix/implement two bugs/features. Random things keep
popping up that I need to work on before I can get to other things such as some
little bit of code failing with Python 2.6 or the latest developer version of
Astropy but hey, it keeps things interesting. I'm at that phase in the project
where I care so much about it that I can't stop working on it. I pretty much
spent the whole of last weekend working (yes, my social life is kind of sad at the
moment) and I don't stop working until late at night. Even if I'm not actively
coding, I read up on documentation of similar packages or read the last 50
commits on the Astropy Github repository. This project has officially taken
over my life, and you know what, I'm having a pretty great time with it!