Monday, November 18, 2013

Installing Ruby on Rails on Mac

Staring this series on my journey of learning Ruby on Rails has been challenging.  Why is it that as soon as you make a commitment to spend your "free time" doing something it seems all your "free time" is gone?  The good news is I have an amazing wife who is understanding and has helped me continue moving forward with my goal to learn Ruby on Rails.

The first thing I needed to do was install Ruby on my Macbook Pro.  Yes, even though I am a Microsoft developer by day I only own Macs.  I made the transition around 6 years ago after building my own PCs since I was in high school but that is another topic for another blog post.

All Macs come with Ruby installed and since I recently upgraded to OS X Mavericks Ruby version 2.0.0 was already installed.  So my first step was complete or so I thought.

Using this Ruby Mac Install video as my guide I started installing the following:

  1. Install git v1.8.3.4
    • I already had git installed and a nice prompt setup thanks to my good friend David Hudson.  Here is a picture of it:
      • Feel free to go to my github repository and copy my prompt logic from the bash_profile that is checked in there if you would like a prompt like this.
    • Install curl v7.30.0
    • Install rvm v1.23.15
      • Used this command: \curl -L https://get.rvm.io | bash
        • Next use this command to install requirements for rvm based on the rvm website's install instructions: rvm requirements
        • Be sure that the [[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm" is in your ~/.bash_profile file

        • Install ruby v2.0.0-p247 
          • I thought since ruby was already installed on my Mac I could skip the step in the video to install ruby using rvm install 1.9.2.  So even though I didn't discover this until the step in the video to create a gemset I put this here so you knew you needed to install ruby using this command: rvm install ruby

          • Create a gemset in rvm for this tutorial

            • Install rails v4.0.1 - decided to use 4.0.1 based on the Ruby on Rails blog.
              • Rails can be installed using this command:  gem install rails --version 4.0.1

                • During rails install there were several ...unable to convert "\x89" from ASCII-8BIT to UTF8 for... error messages.  A quick google search found this stackoverflow question and answer.  This suggested that I needed to update my version of rdoc and then regenerate all my documents with the newer version of rdoc.  Here is the screenshot of the commands:


                    Now that I have ruby, rails, and a few other necessary tools installed I plan to spend some time over the next few weeks learning the ruby syntax and how to build a simple application in ruby on rails.

                    Until next time continue learning!

                    Monday, November 4, 2013

                    A .NET Developer Learns Ruby on Rails Series

                    I have been developing business applications using Microsoft technologies for over 12 years and really enjoy working with them.  However, learning a new language has been on my mind for some time and this weekend I decided to start that process.

                    This is the first in a series of posts that will capture my journey of learning Ruby on Rails as a C# .NET developer and setting up a development environment on my Macbook Pro.

                    Here is a list of resources that are being used to learn Ruby on Rails:
                    1. Installing Ruby On Rails On A Mac blog post by Bret McGowen
                    2. Ruby on Rails Tutorial installation video by rubyonrailstutorial
                    3. Ruby on Rails Tutorial book by Michael Hartl
                    4. Ruby on Rails - A Jumpstart for .NET Developers pluralsight video by Dustin Davis
                    As I continue to learn and develop, I will be adding to this list other resources and refer to in in the coming posts.

                    If you are currently learning a new language and have any tips please post a comment or send me an email with your advice to paul [dot] gower [at] gmail [dot] com.



                    Saturday, August 10, 2013

                    My Code Kata Talk

                    I had a great time this past Thursday night (08/08/2013) at the Little Rock .NET User Group meeting.

                    Thanks to everyone who came out to watch my presentation on Code Kata.  Here is a link to my slides in case you missed it or wanted to view the slides again.

                    Also I wanted to give a big thanks to David Hudson for setting up this code kata website for us.  Starting Sunday, August 25, 2013 I will be publishing a code kata every two weeks and I look forward to seeing you there.

                    Wednesday, April 3, 2013

                    Web.config and IIS7 Woes

                    Today I spent the majority of my day trying to debug why our QA environment would not work to only figure out one of the two issues.

                    It was supposed to be a simple 30 minute x-copy deploy but it turned into an almost 7 hour deployment.

                    The first set of issues were basic server setup issues like ASP.NET and WCF not being registered properly into IIS.  Once I was able to finally get the website up and running against the QA database I discovered a major bug.  Of course I hadn't encountered it in my development environment and just like the old saying "It worked on my machine!"  Truth be told I don't like that saying very much but it is usually unfortunately true.  As most developers know the hardest type of bugs to find are the ones you can't reproduce easily.

                    Now I have a major bug that is going to cause QA some headaches but on top of that I discover that JavaScript code is not working.  The ASP.NET AJAX functionality was not working properly and was even causing the Infragistics controls to not function at all on some of my pages.  This was a bigger issue than the major one I found initially.  After spending way to long on this issue trying to determine if it was an Infragistincs control issue or if it was a server setup issue or an IIS configuration issue here is what I found to be the problem:

                    The <system.web> section is for IIS6 and below; whereas, the <system.webServer> section is for IIS7. The issue was I had the <httpHandlers> section in the  <system.web> section which I thought was enough; however, I did not have the <handlers> section in the <system.webServer> section.

                    Unfortunately this code was in my web.config in the version that is checked into TFS but some how it was removed which caused me to waste over half my day debugging issues.  So hopefully this blog post will help someone else not waste a half day like I did or if I come across this issue again I can hopefully remember to search my blog before wasting too much time!

                    Tuesday, November 13, 2012

                    Setting up DBMail in SQL Server 2012

                    Recently I needed to setup database mail in SQL Server 2012 and here is what I did (so if/when i have to do it again I will remember how to do it):

                    Run this script to create the sysmail account and profile:
                    use msdb
                    GO
                    DECLARE @ProfileName VARCHAR(255)
                    DECLARE @AccountName VARCHAR(255)
                    DECLARE @SMTPAddress VARCHAR(255)
                    DECLARE @EmailAddress VARCHAR(128)
                    DECLARE @DisplayUser VARCHAR(128)
                    
                    SET @ProfileName = 'DefaultDBMailProfile';
                    SET @AccountName = 'DefaultDBMailAccount';
                    SET @SMTPAddress = 'smtp server address goes here';
                    SET @EmailAddress = 'from email address goes here';
                    SET @DisplayUser = 'from display name goes here';
                    
                    EXECUTE msdb.dbo.sysmail_add_account_sp
                    @account_name = @AccountName,
                    @email_address = @EmailAddress,
                    @display_name = @DisplayUser,
                    @mailserver_name = @SMTPAddress
                    
                    EXECUTE msdb.dbo.sysmail_add_profile_sp
                    @profile_name = @ProfileName
                    
                    EXECUTE msdb.dbo.sysmail_add_profileaccount_sp
                    @profile_name = @ProfileName,
                    @account_name = @AccountName,
                    @sequence_number = 1 ;
                    

                    Run this script to enable Database Mail on the server (MSDN Link to Database Mail XPs Server Configuration Option):
                    USE Master
                    GO
                    sp_configure 'show advanced options', 1
                    GO
                    reconfigure with override
                    GO
                    sp_configure 'Database Mail XPs', 1
                    GO
                    reconfigure 
                    GO
                    sp_configure 'show advanced options', 0
                    GO
                    

                    To test and make sure you have it setup you can use this script:
                    EXEC msdb.dbo.sp_send_dbmail
                    @recipients = 'to email address goes here',
                    @body= 'Test Email Body', 
                    @subject = 'Test Email Subject',
                    @profile_name = 'DefaultDBMailProfile'
                    

                    Please note: many of the variables in the above scripts have test data in them. Be sure to set the variables to the values that apply to your environment.

                    Wednesday, September 19, 2012

                    Robots.txt file in MVC3

                    Recently I was asked to look at adding a robots.txt file to a client's website that we built on ASP.NET MVC3. So I did some research and found out some interesting information about the robots.txt file.
                    1. The file is just a suggestion and bots are not required to follow what you ask them to do via the robots.txt file.  
                    2. The file is really an exclusion list instead of an inclusion list.  This means you have to put the places you don't want the bots to view which could be a bad idea in that it would give the bad bots areas they should focus on hacking.
                    After my research we decided to not put a robots.txt file on the website initially. Soon after our deploy we noticed in the ELMAH logs that we were seeing a considerable amount of errors which contained this error message:
                    The controller for path '/robots.txt' was not found or does not implement IController.

                    So now we decided we at least needed an empty robots.txt file out there to prevent all these unnecessary errors. So I did some more research and developed a solution for MVC3:
                    • Basically you just add the physical robots.txt file to the website by adding it to the project at the root level. It could be empty or could contain the basic level of content required in a robots.txt.
                    Now that you have the physical file on the website it will ignore the ASP.NET MVC3 routing as long as you haven't changed the default setting of the RouteExistingFiles property of the RouteCollection which will ignore routing if a physical file is found that matches the URL pattern.

                    To ensure that the physical file will always be served up even if someone changes the RouteExistingFiles property you can add the following ignore route code to the global.asax.cs file:
                    routes.IgnoreRoute("{robotstxt}", new {robotstxt=@"(.*/)?robots.txt(/.*"});

                    Your mileage may vary with the robots.txt file and it might not be a bad idea to have a robots.txt with some exclusions if you really need to exclude some of your content from web crawlers or bots.

                    This particular client didn't really need one because most if not all the content of their website required that you log into their website so bots and web crawlers wouldn't get much content from crawling their entire site.

                    Tuesday, September 4, 2012

                    Using BIDS 2008 to access TFS 2010

                    Recently I had a client that needed to use BIDS to create some SSRS reports but they wanted to use TFS2010 for their source control.  The latest version of BIDS is really a VS2008 shell so I knew it wouldn't be as simple as installing Team Explorer.  I was sure I wasn't the first person to come across this issue so I pulled out my favorite research tool and did some research on the exact steps that need to be taken to enable Team Explorer for BIDS 2008.

                    I found several blog posts about the subject but this blog post by Joost van Rossum not only gave me the exact steps to Team Explorer in VS2008 so it would connect with TFS2010 but also was written from the perspective of using BIDS2008 and not just VS2008.  Here is an overview of the steps that Joost lined out in his blog post:
                    1. Install Team Explorer 2008 (download link)
                    2. Install SP1 for Visual Studio 2008 (download link)
                    3. Install VSTS 2008 SP1 Forward Compatibility Update for TFS2010 (download link)
                    4. Once you have all those pieces installed you have to create your server reference like this (http://<serverName>:<port>/<vdir>/<collectionName> (e.g. http://TfsServer:8080/tfs/ProjectCollectionName) which is different than you do in VS2010.

                    So I followed the above steps and thought everything was working great until I tried to log in to TFS using BIDS 2008 and received this error message popup:

                    Unable to switch servers at this time.  The Team Explorer is busy.


                    So I went back to my favorite research tool to do some more research and came across this blog post by Tom Hundley.

                    At the end of his post I discovered that my problem was with a single character!  So as soon as I removed the / on the end of my server url everything worked like a charm!

                    Thanks for the help Joost and Tom!