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!
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.
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!
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!!
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.
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, noweekend 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.