Monday, 10 October 2016

Learning Python part 4: Airport Challenge

My first-week challenge at Makers was to create an airport system using ruby over one weekend. It was tough when I first approached it but it was such a good project covering so many ideas of software design (albiet on a small scale) that I have borrowed it to learn Python.

This project involved a lot of ideas such as:
  • Object oriented design (SRP, dependency injection, encapsulation)
  • Test Driven Development
  • Behaviour Driven Development
  • Testing ideas (stubbing randomness, mocking)
  • Refactoring (class extraction, encapsulation, DRY)
  • Use of different types of syntax of the language
  • Object interactions
  • Dealing with exceptions
  • Similar to technical tests offered by employers
  • Use of Behaviour Driven Development, outside in testing, feature tests
I felt doing this in Python would be a good challenge to improve my command the language syntax and also strengthen my OO design and TDD. 


You can look through my commits and see how I did each section of the tests and code for each user story.

A major issue was trying to stub randomness and create doubles with methods.

At first, I had issues with injecting the weather object in the airport class, so when Airport is instantiated I created a new weather object. Instead, I had to pass the Weather object as an argument in the airport's instance methods that required it. This resolved itself after some research, where I ended up injecting Weather into the Airport constructor (thus decoupling the two objects).

I have already done this project twice using Ruby and Javascript at Makers Academy, so the design ideas were not a problem just the implementation in a new language. Thus this project was definitely a good step in learning the language.

My thoughts so far...

I feel more confident with Python, but still need to do more work. I was given a test in the language Groovy, to build a twitter clone for the command line, I think doing this in Python will be a good way to cement my learning of the language. Although, I think doing another project which is totally new will be better, thus allowing me to think about design as well as review syntax of code and testing.

Generally, after this stage, I feel that syntax and testing is fairly easy to use. Any other program will be more about the design and little about the language features. 

Another task, such as building a web app (with CRUD) will also be another project on the list.

Thursday, 21 July 2016

Learning Python part 3: TDD and Fizzbuzz

Now everything is setup, I can run a program and it's related test, I am familiar with the syntax, it is time to begin writing some tested programs.

I began by completing the world famous fizzbuzz kata using TDD - Test Driven Development.

This helped me learn the following 

  1. get used to producing programs and tests in a systematic way via TDD
  2. Writing simple code to pass a test
  3. practise the syntax by solving problems
  4. read the stack trace to find out where the errors are
  5. apply simply refactoring to improve the design of my code
  6. Construct tests and implement the syntax for the testing framework
  7. Setup a project for code and tests


Fizzbuzz kata can be seen here...
https://en.wikipedia.org/wiki/Fizz_buzz

The aim is to produce a program that is passed a number and using the rules of fizzbuzz to produce the correct output.

My code is here...https://github.com/hanfak/fizzbuzz-python-tdd

If you want to see every step I made in producing the finished program and the tests, view the commit messages and start at the bottom, click on the first commit (best in new tab) and click on split view, and read the right hand side.  The only two files to read are game.py and app_game_tests.py, if you want to read the files alone go to browse file and search for them. Ignore the + or - signs, they just show all the new code and removed code.



To run the program



1. clone the repo to your hard drive, or download the zip file if you do not have access to GIT (really recommend using it)
2. Unzip and enter the folder fizzbuzz-python-tdd
3. run the tests using the commands in the read me ( I assume you have python set up, if not go to this post)
4. To see it in action for the first 100 numbers,  type python
5. load the file, type execfile('app/game.py')
6. type the following after each line press enter (dont include the >, just to show the input prompt)
               >fizzbuzz = FizzBuzz()
                   >for n in range(1, 100):
                    > print fizzbuzz.count(n), 

        7. press enter again and you will see the first 100 numbers with the correct outputs ie fizz etc.


        To run the tests:


        In the folder, type nosetests -v --rednose


        Refactoring


        The program is very simple, but can be refactored to make it much clearer and easier to read, as well as keeping the code clean. I applied encapsulation to the logic in the conditionals by creating a new private method (__divisible_by), this helped DRY out my code.


        Extra

        This was a simpe kata to get used to testing. If I was not very confident, I feel I would have taken another simple kata from here and implemented TDD. 

        Also doing these katas is also good way of practising for technical tests set by employers for prospective candidates. 

        Next...


        Next on the list is doing more advanced TDD (mocks, stubbing), using more python syntax and apply a few more design principles (SRP, injection).


        Sunday, 26 June 2016

        Learning Python part 2: The syntax

        To write programs I needed to learn the language, the syntax to implement any programming ideas (ie algorithms).

        Here are the following topics I wanted to learn:


        1. Variables (create, change, delete, use), data types and their operations
        2. Comments in code
        3. Numbers(integers, floats), expressions, their methods
        4. Strings, print, interpolation, command line input, their methods
        5. Booleans, conditionals, logic, expressions
        6. Conversion between data types ie string to integer
        7. Lists/arrays, and their methods
        8. Dictionaries/hashes, and their methods
        9. Control statements (if-else/ if-else-if/ ternary, case-switch)
        10. For loops, ranges
        11. While loops, break, exit
        12. Functions/methods, parameters, creating, calling, arguments, return
        13. Classes, initialize, instantiating, instance variables, composition, instance methods, class methods, self, 
        14. Date/time library
        15. Importing, modules/libraries
        The following topics I will cover when I need to, as they are not necessary for the majority of code I will build at the moment.
        1. Errors
        2. File input/output 
        3. Lambdas
        4. Bitwise operators
        5. Inheritance
        Plus being able to run the code, using a REPL that you can type code in directly and play around with it.

        The above ideas will allow me to create code and learn how to implement testing and object oriented design later on.

        As I have already done some coding in ruby and javaascript the fundamentals are going to be the same, i.e. if statements, loops, etc. But every language has different ways of writing them down for the computer to run them (for the compiler or interpreter to turn into computer language for the computer to run).

        So I went back to basics and started the track on codecdemy.

        I did not complete all of it, I skipped the file input and output section, I can always come back to this when I need to use it, but I managed to cover all the core ideas that I needed to know. Also, I was taking notes on some of the syntax differences to ruby. This I felt would make a good 'help me guide' to refer to when stuck on how to write an idea/algorithm in python.

        As I have prior experience in coding, I did not bother reading the descriptions for each lesson, instead, I completed the tasks and went back to the examples in the description to help me if I was stuck. This helped me speed through the python track in around 3 hours, instead of the recommended 13 hours.

        NOTE: If learning as a beginner to programming, I would suggest, to take your time learning the syntax, play around with each idea by creating similar examples. Maybe create a summary guide with your own explanations and examples for each part of the codecademy. 

        Learning syntax can be very tricky at first, so I would advise using another resource, as a different explanation might prove useful, try Zed Shaws Learn the Hard Way. A google search for resources will yield some books and links. 

        NOTE: Avoid reading just cause you have not got it. Focusing on reading, typing (no copy and paste) and playing around with it. Only when you have issues with certain ideas, then look for an explanation.

        Testing I can use the language!

        How do you know that you understand or can do something? 

        Well, you don't ask that question and answer yes. As a newbie, you are not in the position to assess yourself as such. You don't know what you don't know! Instead, you need to test yourself. Can you code using the ideas with out any help or explain the ideas clearly without errors??

        To truly know I could use the syntax, I did some Katas (coding problems). Normally, I would use codewars, but codecdemy had a section in the Python track with quite a few katas. Doing katas is a great way of letting go of the hand holding of a tutorial and apply some problem solving together with revising the syntax.

        Solving problems with code is very hard for beginners, as you have to think in a logical and algorithmic way. Being able to change a worded or even a mathematical problem into and algorithm requires a lot of practise. Having a background in maths (or any mathematical background) does help with this, but I still need to practice. Will make a post on solving katas later.

        Test syntax


        Apart from the syntax of a language, I needed to understand the structure of tests. This took a while and I needed to find some examples. This lead me to searching GitHub for example code (by typing 'python tdd' in the search box), and reading the documentation to understand what was going on when I was stuck. Although, Zed Shaws Learn the Hard Way had some info on testing which was useful.

        I also had ipython (a REPL) installed (similar to pry for Ruby) so I can play around with the new syntax. Plus lots of colours and probably other features that could come in handy.

        I am not to fussed about memorising everything, as I will be creating programs and recalling the syntax from memory first (see testing effect). If that does not work or I forget, I can alway check my code notes or the internet, which will also help make that idea stick.

        Another great place to ask for help is stack overflow, it is a great way of formulating the problem that you are stuck on. Which in a lot of cases solves the problem. I would  suggest looking for previously asked questions via Google like typing 'Stack overflow <key words or problem you have>'. If all else fails, ask the question, but be specific, write the code you have issues with and follow the rules. 

        One thing that is bugging me are the indent errors, because of the difference between a space and tab in the editor causing several breakdowns in myself and the python interpreter. At least I do not have to deal with missing semi colons, looking at you Javascript!


        Thursday, 16 June 2016

        Learning Python part 1: The why and the setup

        This week I have decided to learn how to use Python. 



        Python is a popular language, with lots of libraries and has become one the leading languages used for data science and machine learning

        I felt this would be a great way to show people that I could learn a new language and be able to do some programming and apply design techniques to it. 

        I am not perfect at the other languages I know, ruby and javascript, but I feel comfortable in using them, so doing this is also proving to myself that I can learn a language independently. 

        After Makers, I already have a framework of how to go about this and have a plan which I will document my progress here.

        So far the plan I have set myself is:


        1. Setup 
        2. Learn the syntax
        3. Create a test driven Fizzbuzz program
        4. Create a test driven tech test program and apply object-oriented design 
        5. Creating another program, something new like a game using the terminal.
        6. Create a web app or game (any sort of project that uses libraries and/or frameworks)

        The setup


        Aim: Setup system to run a basic test driven 'hello world' program.

        To use python I needed to install the necessary files to create and run python scripts and tests.

        NOTE: This is based on using MacOS and with homebrew installed

        I installed Python using brew install python3 in the terminal.

        NOTE: There are two versions of Python, version 2  and version 3. I would suggest going for version 3 (as done above) as this generally used with web framework Django (and I believe helps if using Windows).

        Next, I created a project skeleton, using this tutorial, I would follow this and run the tests.

        NOTE: A project skeleton, is just how your files and folders are setup. It is always good to separate your tests from the source code via different folders. This does help with big projects with lots of files.

        I used an extra library, to add colour to my tests (I miss RSpec): pip install rednos

        NOTE: 'Pip' is a library manager just like bundler for ruby, or Maven for Java. Pip comes installed with the latest version of Python.

        So to check everything is running fine, I would enter the project skeleton directory ( ie ' cd <project name>' ) and run tests with this command

        nosetests --rednose -v

        The '-v'  add information, ie a description of the test, to show what tests were passed.

        This will produce the following output:

        $ nosetests -v --rednose

        tests.NAME_tests.test_basic ... passed
        -----------------------------------------------------------------------------
        1 test run in 0.003 seconds (1 test passed)

        NOTE: You can just run tests using nosetests if you want a simple output, just a series of dots for passing dots.

        NOTE: Adding '--with-coverage' at the end of the above statement, you can get the test coverage of your code. Focus only on the files that you have created rather than any extra files displayed. Doing TDD means getting 100% coverage!!!

        Note: This is such a common command  I added this as an alias so I could just type in pt (short for python test). Check this tutorial if you want to do this, I have created quite a few aliases for common git commands too.  A really useful one I found is to create a new folder and enter it

        So to create a new project,  I need to copy the project skeleton and rename the folder as the name of the project. Then change all instances of 'NAME' in the files and filenames and I am good to go.

        NOTE: Before going on to creating a simple program with tests, I learned some of the syntax first.

        To complete the setup, I created a basic hello app, which takes a name and returns "Hello <name>" and tested it.  To view this and see how the project skeleton was altered check the code and browse through the files here:



        Issues

        I had a lot of issues setting up a project. I like to separate my tests and program scripts into separate folders, but running the tests caused so many issues with finding the program for the test to run against. Eventually, I found Python the hard way which had a very easy to follow tutorial that helped me setup a project skeleton. It is also a great way of learning the syntax too.

        Using nose to run my tests, solved so many issues that running 'unittest' or the script using python command, were giving me.

        Naming the descriptions of tests were not great, so I decided to use a naming convention so the tests appear in order on the terminal to the order on the test script, rather than alphabetically.

        For example

        test_1_description 
        test_2_description

        I also added doc strings """description in here""" at the start of each test, which gave a nice description of what was happening, kind of like an 'it block' in RSpec. This would show when running nosetests with -v flag in terminal.





        Sunday, 15 May 2016

        Summary of my time at Makers Part 1

        Unfortunately, I have been unable to regularly chronicle my time during the past 8 weeks or so. Time was precious and I needed to focus on the course rather than this blog. 

        Sorry.

        Instead, I will write a summary of my time in general. As I start my final week and the work load dropping considerably I feel I can get a few posts out that will give an account of my time here at Makers. 

        For a real short summary....

        If you want a challenge, DO IT.

        If you want to create something really cool, DO IT.

        If you want to learn a bunch of coding stuff, DO IT.

        If you want to make great friends, DO IT.

        If you want to change as person and learn life skills, DO IT.

        If you want to be comfortable failing, DO IT. 

        If you want to be in an environment which supports you, DO IT.

        If you want to surpass your own expectations, DO IT.

        If you don't mind giving up your life and time everyday, DO IT.



        Monday, 21 March 2016

        Typos

        Monday has become a sort of chilled out day, half the time is spent on code reviews and lectures, and the other half learning new terminology and starting on the weekly challenge. It is nice to start the week in a slow way, but at times I just want to power through the new work. 

        I was with Chris today, the musician/contract killer (his viola case looks like a sniper case). We spent an age trying to solve a problem that has never happened to us before...rspec not recognising it's own method (i.e. 'feature'). We went up the chain of help. Google failed. Our peers failed. The Alumni Helpers failed. The coaches failed. We were pissed.

        In the end, an Alumni Helper, William, decided to look at our code after hours and spot the mistake. It was writing the wrong type of '-' which proved the problem. Sometimes the simplest things are the cause of our problems, but being simple makes them hard to spot. 

        Lesson learned: Be cool when stuck.

        Also managed to get some free homous and bread, which were left over from a weekend event at Makers.


        It was good, but the houmous was very acidic, which I found out later, was a sign the food was off. So I spent the whole day waitin for my stomach to explode.

        Also free cookies and possibly free football.

        In my opinion, the start of week four has been good!


        Sunday, 20 March 2016

        MA Week Two Summary

        General summary

        More Ruby, More TDD

        The main challenge this week was to learn more about applying Ruby using a test driven methodology  (rspec) to create a functional piece of software for the London Oyster Card system. The new skill we learned was all about dependency injection (DI). This gave practically everyone headaches and stress!

        DI is just a way of reducing coupling (dependency of one object relying on another). Low coupling is the aim of good design, objects knows very little about other objects that it sends messages to. No coupling can never happen, as the object cannot be used by any other object. High coupling is bad, it makes changing one object harder to do, as it will affect the implementation of another object. The lower the coupling the easier it is to change or add to code.

        Group session

        Had a great group session with Dana (will talk more about her, but she is great) on Tuesday, involving sharing our thoughts so far on our experiences with the course. It was a real eye opener. We had to express our agreement  with the current speaker by showing 'jazz hands'.

        We spent around 90 minutes doing this but despite my feelings of regret at not coding, I felt this was a great idea to really connect and learn more about my cohort and myself. There were a lot of emotions being shared around, a few personal stories of overcoming setbacks, a few tears, a few people overcoming their fears to talk in public but most importantly a lot freedom to say what you want and be heard with out being judged or threatened.

        I started first, and shared my feelings of feeling stupid, not being good enough, being an imposter, letting my pair partners down. Too my surprise nearly everyone felt the same. Personally, I felt this has held me back a lot in my life, but I am starting to believe that I am good enough and thats alright and all I need to be. Not knowing everything, or feeling stupid or forgetting does not make me rubbish. Class is permanent, form is temporary.

        What was surprising was my pair partner for the day, Andrew, felt the same way. Although I felt he was far better at solving the problem, more confident and learning so much more than me. So it was great to hear he felt the same about me and feel that it is alright to be struggling, it is normal. After the session, we had a hug and managed to finish off the task  for the day.  Then a huge group ended up at the bar, with friendships further strengthened.

        I feel this group of people I am working with now, are going to be in my life for a long time.

        Code review of my weekend challenge

        • Spent the morning with my mentor Jonny going through the weekend challenge (the airport). He was tasked with reviewing my code and helping me improve the style and quality. 
        • Spent time implementing the  changes suggested by my mentor to my code. Spent a lot of time on this, when I felt I should have been doing more pairing on this weeks work. 
        Played football for the first time in years

        Football is organised for every Monday on the five a side pitch located at the back of the offices. I have not played football in ages, so I knew I would stuggle. I did. I was out of breath after 10 minutes and we still had 50 minutes left to play. Yet despite the struggle ( I am seeing similarites with Makers), I loved it. It was like being back at school on the playground kicking the ball around, kicking it over the fence and having to retrieve it (think most were glad for this as it gave us time to rest).

        There was only me, Paul and Si from our cohort, and the rest were seniors and a couple of Alumni playing. It was great game, competitive and friendly. Although we gave up counting goals after 15 minutes, think everyone was too busy gasping for breath to remember.

        Big consequence of playing football and walking for commute are that my legs are like jelly and aching like mad!


        A visit to the POO DR

        As a consequence of a breakout session, we were told to read POO DR by Sandi Metz. This is the bible of good design (SOLID and TDD) with a particular reference to Ruby and bicycle gears. It is a great read, and the topics are well discussed. The big problem is being able to apply them while working through the problems.

        I decided on Thursday to stay late, and implement some of the ideas on dependency injection in chapter 3 to my code, to reduce the coupling. Well worth the time spent, code much cleaner.

        Pair partners for the week

        Monday

        My partner was Yasmin (no J), unfortunately we did not have much time together as we had our code reviews and refactoring (improving our code) to get on with. We did sit next to each other and help each other out. We spent around an hour working on the challenge, but did not get very far, although I felt we did some good review of the basics  that were learned last week.

        Tuesday

        My partner was Andrew and we managed to get through a lot of work together. After the group session, I realised we were at very similar levels and that it was great working together. We had an almighty struggle with problem 12 and I just shouted out in ecstasy when we solved it, which I think disturbed a lot of people (well not many, most had already left).

        This was also my first time that I have had to go and see the Alumni Helpers for help. We have been told to see the AH if Google or one of cohort cannot help us. I have always been one to focus on solving problems myself, regardless how long they took. This is a big mistake. I am wasting time, but I guess my ego is involved. So I was glad to admit that I did not know and get some ideas on solving a problem.

        Wednesday

        My partner was Murilio, from Brazil, and it was a good session partner wise, but we did not exactly do as the question asked and it feels like I have missed out on pushing my learning further.

        Worked late at night, trying to understand what was going on with DI.

        Thursday

        My partner was Junyuan (spelt correctly, which I did not when I was set up GIT, sorry) and it was a tough day. I was so confused by the material, I felt that I did not give as much contribution to the code.

        Friday

        My partner was Erika. We both finished this week's work, so we decided to redo it again from scratch and see how we got on. Due to being Friday, we finished the day at 4pm when the drinks came out.
        Quotes

        "You are not your code"

        MA Application process

        Here is an overview of the application process from my point of view. It is going to be very vague on the details (not good form to give it away and the structure always changes), but follow the tips and you should be fine.

        I did these tips, as I would have liked to have known some of these things beforehand (ie dress code).



        Deciding to apply

        This is the most important part and should spend the longest on this before deciding to accept a place on the course. 

        TIP: Know the exact reason for joining Makers. Use SWOT, pros and cons etc to make your decision.

        TIP: Find people in the software industry and talk to them about their experiences.

        TIP: Research thoroughly the course, company (the website), students views (read blogs like this, talk to them if possible), review sites, Youtube videos. You are going to be dropping a huge amount of money, make sure you know what you are getting yourself into first.

        TIP: Discuss with friends and family your thoughts and if this is worth it.

        TIP: Do some coding before even thinking about apply, you want to make sure that software/web development is the career for you. 

        TIP: Try the following Codecademy and Code School, and try the Ruby or Javascript paths.

        TIP: Visit the offices, and be prepared with questions to ask. I met Ollie, who was really helpful and answered all my questions. Look at the environment, can you see yourself coping and spending lots of time in this place?

        TIP: Make sure you have the money (fees, accommodation, food etc), not only for the course (3 months) but for at least 2 months after the course. Even better for the month you do the precourse (so 6 months in total).

        TIP: Make sure you can fully commit, no work, no other hobbies or holidays planned, no social events etc. You need to make full use of time for learning and resting

        TIP: Be prepared for the craziest, emotional, draining experience of your life.

        TIP: It is going to be tough, tougher than university, than work...understand this and know you cannot really prepare for this.

        TIP: Do not quit your job until you have got an offer and confirmed on a cohort.

        TIP: When Pre course starts, the workload is much bigger than expected.


        Applying

        Now you have made your mind up, great you will not regret it!!!

        The application form is very simple and easy to use. I am not going to write what I put down, but if you really want this new career, love coding and want to join Makers Academy, then it will be easy for you to fill in the form.

        I will not give details, as they may change the process or questions.

        TIP: Write in UK English and use correct grammar, punctuation, spelling and make sure it makes sense.

        TIP: Answer the questions exactly. They are not trick questions, just follow the instructions.

        TIP: Check. Check again. Ask someone else to check for you. Check again. Print out and read your form.

        TIP: I think it took a week to hear back from MA. So do not stress out checking email all the time.

        Interview work

        If you are successful, you will receive an email with a set of instructions. 

        It will have a list of things to learn for the coding test and the structure of the interview. 

        TIP: Over prepare for the interview, think of lots of questions that could be asked (check Google for interview questions) and write notes and answers to them. 

        TIP: Do the set work. Even if you have done it before, do it again. Don't memorise the answers to the problems, that will not help at all. 

        TIP: You will have a week or so to prepare, plan your time wisely and stick to it. Do not leave it to the day before.

        TIP: You will be sitting very close to the interviewer, so make sure you wear clean clothes and smell good!


        Interview

        Again, every interview will be different, so I will not divulge what happened. 

        There will be a few questions, a logic test and a coding test, although this is not set in stone and it might be different for each candidate.

        During my interview, they were trialling a new software for the coding part of the interview which was weird at first, but really good. Plus Nikesh, was really helpful and made the whole process feel very relaxed (especially when one of the laptops decided not to work!!!).

        I think I over prepared, but that was great as it gave me confidence to handle anything. Plus all your notes will be useful for applying for jobs afterwards.

        TIP: Once you made it here, just relax, and be prepared. If you really want it then you would have done enough to get it, if not then you should have done more. Better to be over prepared than under. 

        TIP: Check out Google for interview techniques. 

        TIP: Do not lie, be yourself. What they are looking for, in my opinion, cannot be faked.

        TIP: Drink water during the interview. 

        TIP: Dress code, I was at a loss here as love wearing a suit, but this is coding and everyone is pretty relaxed. So just be smart, no need for a tie or suit. For a guy, shoes, trousers/dark jeans and ironed shirt (and jumper) should be good. Just be comfortable in your clothes and make sure they are clean and ironed!

        Here is some motivation music, if you need some pumping up, to hear before the interview:


          

        Acceptence

        My acceptance came within a couple of days of my interview (I do not know if this is usual). I was checking my email every half hour, I was so nervous, but it worked out great in the end.

        I had around 15 days before the pre course started, so more practice to do. 

        TIP: Follow the instructions and read everything in the email.

        TIP: Make sure that you are certain again, go through all the reasons and feelings for doing this.

        TIP: Get all your affairs in order before starting the course (leave your job, sort out finances and budget, etc), time will be at a premium when you start the course don't waste it on admin.

        TIP: If there is lots of time before the start of the pre course, then start to do some extra learning and practice (get comfortable with command line, git, and go over ruby and do lots of problems)

        Rejection

        Luckily, I did not get this email. But if you did, do not feel too downhearted. If you really want to do this than you will find a way to make it happen.



        TIP: Ask MA why you did not get a place and what you could do about it next time.

        TIP: Try another bootcamp.

        I have been here for three weeks, and I love it, I love the work, I love failing, I love the students, I love the atmosphere, I love the coaches...This is going to be one the best things you ever do, it is not perfect, but it is great!


        Tuesday, 8 March 2016

        MA Week One Summary

        What I did?

        Monday

        • First day, and it was very easy and relaxed. Only a little bit of coding.
        • Name game. Too long
        • Free breakfast and talk with others
        • Social after
        • paper challenge with Junyan
        • Talk with Dana and Jordan about how to cope with course
        Tuesday
        • Had a short introduction about the structure of the course
        • Started working with my pair partner Patrick
        • Worked through the first challenge, creating Boris Bikes, implementing object oriented programming (via Ruby) and Test Driven Development (via Rspec).
        Wednesday
        • First stand up in our group with Roi, discussing our wins and struggles from yesterday, and our plans for today.
        • Worked with Kevin, who has a great blog here, decided to start the weekly challenge from scratch due to issues with git and wanting to cement the basics.
        • Joined the meditation group, and did some mindfulness exercises.
        Thursday
        • Worked with Harsheet, continued from question 16 out of 22 and used his code as a starting point.
        • Played Ping Pong, and got beat twice. Revenge is on the agenda!!
        Friday
        • Worked with Pete, continued from Q20 till the end (see here for my code)
        • After 5 received free drinks and partied with the rest of Makers till midnight.
        Weekend
        • Worked on Airport Challenge
        • Went over the Boris Bikes Challenge alone, to cement the work.


        What I learned?

        • Big Breakthrough 1: Hammering home that everything in ruby is an object, and ruby syntax is useful but stops the user from seeing this.
        • Big Breakthrough 2: Using mocks in tests, to avoid creating objects from other classes, to help create outputs to help test specific methods.
        • Big Breakthrough 3: Understanding the idea of Behaviour Driven Development, as an overarching methodology to produce software. It really helped see the forest from the trees (implementation and unit tests) 

        Challenges and struggles?

        • Struggling with turning user stories into features and feature tests
        • Doing TDD, instead of just normally doing the code first.
        • Feeling dumb and coping with this
        • Working with someone who knew more than I, and feeling like I was not contributing
        • Getting used to working with a Mac. It is the first time I am using one, so I am a bit slow compared to using a unix/windows laptop.
        • Trying to write this blog. It is very hard to find time to write this blog and deal with the course and life. I think I was ambitious in doing it this way, so I will need to do it in a different format.

        Success?

        • Finishing off the challenge before the end of the week, despite starting again
        • Using someone elses code base to work from
        • Finishing off the weekend challenge, despite restarting three times
        • Doing meditation twice during the week
        • Working well with my pair partners, and learning lots from each of them
        • Still writing this blog
        • Walking to office and home, 5 times during the week
        • Bringing packed lunch (warm meals with my thermos) everyday, and avoiding eating out and saving money
        • Walked over 10,000 steps twice during the week. 
        Other
        • Party on Friday at Makers was great, a great time to really relax and socialise.
        • Going to football next week
        • Spending time with cool, interesting, fun smart and driven people. Nikesh was right, I have found like minded people who I feel I will be friends for a long (whether they will be with me another matter :-( )
        • Really happy with my choice to attend this course, it is really draining and lots to take in. Yet by the end of the weekend I felt that I grasped a lot of new ideas and was able to understand a lot.



        Tuesday, 1 March 2016

        MA Precourse Week 4

        What was done

        • Practised more ruby through completing code wars' katas (not as much as the previous weeks).
        • Met my mentor and did pair programming together.
        • Completed the fizzbuzz kata in ruby using a rspec as the testing framework.
        • Pair programmed with some of my fellow cohorts.

        What was learned
        • Learned about "Test Driven Development" (TDD for short).
        • Learned and practised some basic rspec (TDD framework for Ruby) on some basic katas.
        • Learned the basic structure of rspec tests for methods. 
        • Learned about regular expressions.
        Struggles
        • When pairing and knowing what was already being explained, but not wanting to sound arrogant. 
        • Pairing in general, very weird not to do my own thing. Although when doing it with Patrick, I just turned my computer off, so we could work together and not be distracted.
        • Writing tests firsts instead of figuring out the method then coding and testing if it works (this is how I approach code wars katas). 
        • Setting up the files, directories, accessing the lib files in rspec.
        • Pairing with Patrick, spent ages on this kata, and two other guys (Tobenna and Paul) both managed to finish it before us and with less code. Despite this, I still felt it was a great learning experience having to explain my ideas and solve problems as a pair.
        • Struggled with using look arounds in regular expressions.
        Successes
        • Getting more confident with using regular expressions. I managed to do a quite a few katas on code wars using regex, and I am very happy. I am not perfect, and there are aspects (ie look ahead and look back) which I struggle on. I have got some resources to help me with so I am happy. 
        • Doing some pairing, and not ending up spooning each other (see video below) 
        Other
        It was him shooting at me at Makers
        • Met my mentor, Jonny, at Makers and spent a couple of hours going through the fizzbuzz rspec pairing tutorial. Jonny was great, and really helpful, he spent so much extra time going through some key ideas on rspec and classes. I feel lucky to have him as a mentor. 
        • While pairing with my mentor, someone decided to rain down on us nerf bullets. Which was a bit of a shock, but all in good fun.
        • Last week of Pre course, and it was a very easy and relaxing week, no weekend challenge (well it was catch up, which meant no work for me as I did everything on time due to not working).
        • Finally going to start, on Monday 29th February, and I am excited and nervous. But not as much as when I started pre course, I have met and worked with a bunch great guys from my cohort at the Ace Hotel, and the chat, via slack, conversations have been fun and helpful. So I can not wait to start working with them.
        • Went to Ace on Tuesday, and we had almost 10 people come in and work. It was great, we had a laugh, helped each other, encouraged each other. Who would have thought coding would be so social. 
        • I have finally been given the code to the Makers office, so no more going through the intercom. I finally feel I a student at Makers.