My birthday this year was also the penultimate day of school for the girls and a remote-learning day. I worked from my closet for the morning while the girls got their schoolwork done and took the afternoon off. After lunch we went for a short walk at Sycamore Grove mainly as an excuse to get out of the house. The weather was probably the coolest I've had for a birthday in over a decade with a high of about 65F.
Our Sycamore Grove "hikes" rarely make it further than the hollowed out tree about a half-mile along the trail. But it makes a good stopping point and fun pictures:
After our walk in the park it was time for the girls' art class. Jess dropped them off and I sat on the couch and read a book while the house was quiet.
Once the girls were home from art class I opened presents!
With presents opened it was time to figure out dinner. I drove out to the Cheesecake Factory to pick up food--the spicy chicken chipotle pasta is yummy.
And, of course, after dinner was cake!
Bonus picture of Heather with her eyes crossed:
After work on Friday we went to Boomers! and played miniature golf to celebrate my birthday and the end of school.
Yesterday, Saturday, we went over to some friends' house and played a board game. With vaccinations going into effect and infection rates dropping life is starting to go back to normal.
Corinne and I got 2 pandemic birthdays, but it looks like Heather and Jess will only have one. Alameda County moved to the yellow tier this week and California is still planning to lift most remaining state-imposed restrictions this week on the 15th (there will still be some restrictions on mass gatherings). Messaging has been unclear and I'm not sure if Alameda County will retain any restrictions beyond the state's or not.
I've been working on painting this figure from the "Gloomhaven: Jaws of the Lion" game a little at a time for several weeks now. The figure is 1.5 inches tall, so the detail work is pretty tough. This took about 13 hours worth of time. It looks somewhat less impressive in blown-up, high-detail photographs; so just zoom out and imagine it being quite small so the errors in detail are less noticeable.
Overall I'm happy with how it came out.
There are 4 characters in the game, so three more to go. This may be the most detailed one, but I painted it first because it's the character I'm playing.
After celebrating Corinne's birthday at the very start of the quarantine I honestly didn't think we'd still be quarantined by the time my birthday rolled around. But here we are.
I started my day by working in my closet. Then lunch in the kitchen and back to my closet for more work. Very exciting.
Once I was done with work, I opened presents:
Here Heather is using her "Poison Rod" to protect me.
The girls gave me new sets of miniatures to use in our Dragon Strike games. Corinne here has her "Fire & Ice staff."
Jess gave me a set of fancy vanilla extracts: Tahitian, Mexican, and Madagascar Bourbon types. I need to come up with a dish to make to let us taste test them.
A careful observer might wonder why the box on the right says "VHS" on it. That's the Stranger Things seasons 1 & 2 sets which are packaged to look like 80s-style tapes.
After presents I picked up some Mexican food for dinner from Anita's Tacqueria. Since no one else likes Mexican food, Jess made pasta for everyone else. After dinner we needed some time to digest before having cake. So I played a video game for a little while.
We didn't have enough candles, so I told Jess to use a binary representation. Since the cake is facing me you have to read the binary backwards. So the right-most candle represents a "one" for 32 then there are 3 "zeroes" for 16, 8, & 4 and finally 2 "ones" for 2 & 1.
After dessert the girls headed off to bed and Jess and I watched the 1971 classic movie The Andromeda Strain.
July marked the 10-year anniversary of my starting work at the Lab. I got a certificate and lapel pin (not that I ever have any lapels on which to put it). And also a bump in vacation time and 401k contributions.
I'm still working with the same group I started with on the same general applications. But a lot has changed in that time.
Falling into the Past
When I started, the existing development team had collapsed for unknown reasons. I joined a basically black-box pile of software written in Java with custom, homegrown libraries and support packages. No documentation. Some of the compiled code had no matching source code (that I could find anyway).
It was a bit like being thrown back in time by at least 10 years in how web applications were built. I can admit now that it didn't take long before I felt a bit worried about whether that job was going to be at all fulfilling for me. The code was a mess of JSP files intermingling core business logic with HTML output (a la the bad old days of PHP). It couldn't be run locally, so making a code change involved modifying source files, compiling the code, deploying to the test server, restarting the application server (which also hosted the production application, so restarts impacted users), and then testing the change. A round-trip process of 15+ minutes. It was brutal.
I came in to the job with web application experience and I knew that there were much better ways of developing web applications. It wasn't fusion research--that's a different department--it was a fairly mature world.
By the Fall of 2009 I had settled in enough that I felt comfortable (or maybe just desperate?) enough to pitch the idea of using an open-source framework for our applications. Essentially saying, "Let's toss the existing codebase and start over."
Thankfully, my manager (who I'm grateful is still my manager) was willing to hear me out. But, we had some restrictions. The IT group was run separate from the software team and they dictated our deployment environment. So whatever we did needed to still run on the Solaris operating system, using Oracle Weblogic for the application server, behind Oracle iPlanet web server, talking to an Oracle database.
Even in 2009 that technology stack was unpopular at best and approaching obsolete. Trying to figure out how to configure Weblogic or iPlanet resulted in reading a lot of forum posts like "How do I do this in Weblogic?" answer, "You don't, use literally anything else." And that was if you were lucky enough to find an answer at all.
I had experience working with Python/Django, but that as a non-starter. Can't deploy a Django app on Weblogic. It was a Java world. And our IT staff wasn't much interested in supporting anything they didn't already know.
Stepping into the Present
I found the Grails framework which lives in the Java ecosystem (technically it's Groovy, but it runs on the JVM and as far as the system was concerned it was Java). It looked promising, certainly a huge step forward from what we had. We could go from coding with both arms tied behind our backs to one arm in a sling (which I did literally for a few weeks when I broke my arm, but that was years later).
I prototyped a brand-new type of application for our system. A geospatial view of the data utilizing Google Earth in the browser (back when GE was a browser plugin). Using a real framework I had a functioning prototype in a couple of weeks and it became immediately obvious that this was going to be our future.
That prototype was fleshed out into a full application and has since been overhauled 5 times and remains one of our core applications. It would never have been possible without moving our development work to Grails.
Over the past decade I kept pushing on modernizing our infrastructure as much as we could. Eventually the IT staff were consolidated under the software manager and over time they were replaced with people willing to consider a world outside of Solaris.
We moved our infrastructure to RedHat Linux, migrated from SVN to Git, switched our application server to Tomcat, finally swapped iPlanet for Apache, and even dumped the Oracle database for Postgres. We were finally in a sane development world (not to mention saving, literally, tens of millions of dollars on hardware and licensing). The arm was out of the sling and we got a lot of work done.
We had added additional software team members throughout the years, but never had a real focused approach to creating software. We were making it up as we went along and if you looked at the code, it showed.
In some ways, this was a necessity. As I said, the software team was non-existent when I joined. I had no experience managing a "real" codebase. Certainly not one expected to last for years. But, at the same time, the broader group we supported--the people we were trying to make more effective via software--didn't have any trust in the software team. We needed to give them wins quickly to show them it was worth their time to interact with us.
And that's what we did. That first prototype gave them a way of working with their data they never had previously and they wanted more. So, rather than work out a disciplined approach to building software with no experience to guide us, we wrote code. A lot of code.
Building the Future
It's now 2019 and, for myriad reasons, it's time to leave Grails behind. This year I became the team lead for the software group so I've had a lot of decisions to make. But, this time I have 10 years of experience to draw on.
We're moving our applications to Python/Django. Something we could have done in 2009 had the IT staff been supportive of the software needs. But it is what it is. The good thing here is that it means the codebase will start from scratch. And, having had 10 years of dealing with a codebase built on the whims of the individual developers, we are doing things differently.
Our legacy applications are functional and stable so we have time to do things right. I spent a huge amount of effort up front picking the tools we'll use to maintain good code "hygiene." That is, tools and processes that ensure code is written consistently, that tests have been written, that obvious bugs have been caught, that the tests actually run and pass, etc. This discipline is already making a big difference in code quality.
We also have the luxury of an existing suite of applications--which we have to migrate over to Python--but which means we know what we're trying to build ahead of time. A lot of our work in the past 10 years was speculative: we think this would be helpful, let's build it and see what the users think. And a lot of it was trying to meet user demands when the users didn't really know what they wanted, just a vague idea.
Our first rebuilt-in-Python application went to production in October. It took longer than expected, but I feel really good about the quality of the code in it.
Supposedly, software developers in the Bay Area switch jobs, on average, every 3 years or less. So why have I stayed here for 10?
I like my job. I like the work I'm doing. I like my manager. I like my coworkers. I like that I live 6 miles away and don't have to get on a highway to commute. I like the impact my work has. I like that I can effect meaningful changes that improve our products. They don't happen fast or all at once, but I'm quite sure I'd be doing something else if we were still writing everything in house and deploying on Solaris.
The nature of the projects I work on prevents me from saying much of anything about them, but I find the work meaningful. I'm not spending my days trying to figure out how to get more ads in front of more people. Our software has international impact on a regular basis with the goal of improving not just national security, but global security.
I'm not going to get rich, but our health insurance is great, we're saving money for retirement, we managed to get a house while prices weren't insane, we're building up long-term savings and work stays at work. I don't bring a laptop home, I don't work on the weekends. I don't answer emails after dinner.
I like what I'm doing, so I'm going to keep doing it.
On my birthday we went on a family adventure to Japantown in San Francisco. I had a goal of finding a bamboo fountain (a shishi-odoshi fountain). I was unsuccessful in that goal, but I did find some neat ceramic dishes and a sake set because I think it looks neat.
Our adventure in to the city just about did us in. But did go out to dinner and then get back home for cake.