The strangeness of conventions 11/01/2011
Yes, I'm an old fuddy-duddy. I started programming back in the 80's and learned Turbo Pascal and Modula-2. I still remember that making code readable was about using helpful names for variables and functions... and ALWAYS make sure those names were visually different so that you wouldn't confuse them. (e.g. $user, $users, $Users) Well, welcome to the world of Ruby on Rails. if Michael Hartl's tutorial is any indication, then this world is chock full of references to things that all look the same. So far, I've discovered that the following are very VERY different, yet they look so similar. These are all variables, instances or classes. (I get so confused!) user users User @user micropost microposts Micropost @micropost And yes, I do find all this hard on my tired old eyes. While it might "read more like English" I have to wonder at what cost. I'm sure someday I'll lose hours trying to find a bug that was more about a missing (or extra) "s" than anything else. If being readable means that my code is hardly debugable, then maybe we've "swung the pendulum" too far! Add Comment What I hate most about being a newbie... 11/01/2011
Sure, we all have to learn something new at some point. But what I hate the most is the solution that you can't learn from. So, I spent yesterday working on Chapter 11 of the Rails Tutorial. It's been great, but there was a "re-factoring" section in the middle that I knew was going to haunt me. There were too many changes, too many RSpec test added and and the development was just too much. My code "blew up" on me. I had at least 14 tests go red, and the solution that should have been obvious was completely hidden behind all my attempted fixes that only made things worse. So, I blew away all my Chapter 11 work ("git reset --hard" takes you back to your last commit). I started again, and when I got to the "too busy" part, I broke it down into smaller chunks and went by baby steps (with a complete RSpec run after every step). Did I find my problem? NO!!!!! Every RSpec test passes now with flying colours. The big step (I had thought) was to move "def authenticate ..." from the users_controller to the sessions_helper. I moved the code, ran the test, held my breath, ... and it ran green! For once, I really wanted my code to blow up (so it would justify all my pain from yesterday). What I had spent an hour researching and 2 hours repairing... was not a problem ... at all. (groan) So, I have no idea where my code went wrong yesterday, so I have nothing to learn from my mistake. However, maybe my biggest mistake was to "follow the instructions" when my gut said, "Take it slow or you'll get lost!" So, that's the lesson of the day. Take your TDD in baby steps (and don't worry if it feels slow, because the alternative is ... ARGGG!) [TDD = Test Driven Development] What is happening when your code runs fine, the tutorial shows that your code should be "RSpec green", but it isn't? For me, it's time to go to StackOverflow.com again. The hardest part was searching for the right answer. But once it was found, it just works! So, for those of you stuck in (Michael Hartl's awesome Rails Tutorial) chapter 10 and wondering why you now have RSpec giving you 7-10 errors, don't worry! I had suspected all along that this was just one of the differences between Rails 3.0 and Rails 3.1, and it appears that I was right! When searching for "test_sign_in" the 4th hit took me here, and the answer redirected me here, where I received the bizarre but efficient changes that needed to be made. In sessions_helper, find def sign_in
[TDD = Test Driven Development] Learning how RSpec works 10/24/2011
RSpec seems to make such intuitive sense, and now that I've started to wrap my head around TDD, I am starting to see the benefit. Sure, initial development may be slower, but the overall development approach should help over the long-term maintenance of your code. But then, RSpec completely stumped me. Thanks to the folks at StackOverflow, because this post, explains my problem exactly. After multiple tries, my test just wouldn't work. But with this explanation, I started wondering how the "click_link ...." test was working. Then it hit me: each "click_link" represents a user click, so the following test is now looking at the new page (just "clicked") and not the path I had specified above. AHA! Very interesting (and, sadly, unintuitive for the newbie). Heroku now working (...sigh...) 10/24/2011
Small victory dance. (My Heroku solution was here.) Knowing how much more there is to come, I'm a little overwhelmed. By the way, big kudos to the people who provide answers at StackOverflow. For all the scouring of the web that I've been doing, the best answers keep coming from there. Thanks to you all! Now, back at the tutorial! I've read all over the web that "deploying to Heroku is totally painless!" Wow. 2 days later, and my best answer was to start over, line by line. Now, granted, I'm a complete newbie to Rails, so I'm sure to make every mistake possible. But, wow, Heroku has been a complete pain in the ass! First, I'm discovering that Heroku doesn't believe in error messages. They simply state:
Second, Git is a newbie nightmare! Seriously! All I wanted to do was back up 5 commits! How hard should that be? I wanted everything I had done in those 5 commits to be UNDONE. Isn't that the point of a versioning system? Yeah, well, if there's a way to do this, then please let me know. After searching all over the web and trying a number of "solutions", I ended up starting the tutorial over from scratch. (Write one line of code, git commit, git push, git push heroku, test/verify.) All the TDD that RSpec uses is great, and all the local testing passed with flying colours! Then, upload to Heroku and watch it fail! So, now I'm trying to figure out what exactly is the cause. I'm completely baffled, but so pissed off that I won't give it up. Maybe I'll post more here as I go. For those of you who are curious, here are my Heroku failures to-date (all of which yielded the exact same error screen described above):
One final thing: I spent hours trying to figure out how to setup the database config for the production (i.e. Heroku) site. Then I found the link describing how to get this. But there's not need to post it here, because then I found out that Heroku re-writes your production database config on upload (i.e. git push heroku). So, there's no need to worry about this after all. [...sigh...] Learning Rails -- Hiccups along the way 10/13/2011
So, as I've posted in my bio, I've been learning Rails lately. (Full name: Ruby on Rails)
I've been using Michael Hartl's RailsTutorial.org/book and it's been fantastic. I've thought long and hard about paying the $85 for his screen-capture-videos, but with being unemployed, I've decided to go the free route. The tutorial is amazingly detailed and the explanations are fantastic. Michael does a great job of bringing the new-to-Rails programmer. ... |

RSS Feed