Near Earth Objects is an educational command line tool that strives to interrupt the monotony of day to day living by allowing users to understand how close to extinction life on earth is at any given point in time. Every day thousands of NEOs (Near Earth Objects) i.e. comets, astroids, meteors pass by the earth at alarmingly close distances. One slight shift in the cosmos would cause these NEOs to crash into the earth, setting off a series of catastrophic events that would lead to the end of life as we know it (much like the fate of the dinosaurs). Now that we've discussed this, please take a moment to appreciate 3 small things in your life that you take for granted and assume will always be there...
Please follow these instructions for further enlightenment.
- Clone this repo
- Run
bundle install
to download and install all of the necessary dependencies - This project uses NASA's Astroids - NeoWs API. Please signup for an API key here
- Once you have your api key, run
bundle exec figaro install
. This should create a file calledapplication.yml
located in theconfig
folder. Note: This file is automatically gitignored and many IDEs do not show gitignored files by default. You may have to change your IDE's settings to show gitignored files. - Append your api_key to
application.yml
in the following formatnasa_api_key: <Your API KEY Goes Here>
- This project uses minitest. You can run the tests with the following command
ruby near_earth_objects_test.rb
- To use the command line tool run
ruby start.rb
. You will be prompted to enter a date. Enter the date in the following formatYYYY-MM-DD
i.e.2019-03-30
. Once you hit enter you will see information about the objects that came near to the earth on that day.
With your partner look through start.rb
and near_earth_objects.rb
- Discuss is this 'good' or 'bad' code? Why?
- It’s functional, but could definitely use with some more organization. It uses a lot of variables to keep track of things, when methods could be used instead. It also does a lot of formatting and I wonder if that could be changed by either 1) using some sort of gem or 2) making this a Rails application to have a better user experience.
With your Partner, identify the different responsibilities that exist in each file.
-
Does this adhere to SRP?
- Not really - they could use a third class called something like Formatting where all it does is handle all the formatting. And another one to Calculate, and another for User input, so the start.rb file would just be maybe running one line of code which cascades everything else to work.
-
How would you utilize encapsulation and abstraction to refactor this code?
- I would abstract out at least 2 other classes to make sure what each class does is very clear and direct. Those classes (and the class that already exists) would only have access to data of the classes they need to.
-
What tools/strategies could you utilize to make this code adhere to SRP?
- Create more classes
- Create more methods in those classes
Declarative Programming:
- Write the code you wish existed above the existing code
- Keep the code that is currently working. Don't delete it until the new code is working. This way you will always have a passing solution
Red, Green, Refactor:
- Utilize tests to keep you moving in the right direction
- Follow the errors in the test to guide you each step of the way