Git Product home page Git Product logo

bank_tech_test's Introduction

bank_tech_test

IRB screenshot

image

Rspec and test-coverage screenshot

image

Requirements You should be able to interact with your code via a REPL like IRB or the JavaScript console. (You don't need to implement a command line interface that takes input from STDIN.) Deposits, withdrawal. Account statement (date, amount, balance) printing. Data can be kept in memory (it doesn't need to be stored to a database or anything). Acceptance criteria Given a client makes a deposit of 1000 on 10-01-2012 And a deposit of 2000 on 13-01-2012 And a withdrawal of 500 on 14-01-2012 When she prints her bank statement Then she would see

date || credit || debit || balance
14/01/2012 || || 500.00 || 2500.00
13/01/2012 || 2000.00 || || 3000.00
10/01/2012 || 1000.00 || || 1000.00

How it works

clone this reposition, run bundle install in your terminal and you can interact with the code via IRB. In IRB require './lib/app.rb' type in account = Account.new and then you can make transactions with account.deposit(amount), make a transaction with transaction = Transaction.new(value, type, date ) put it in the log like so log = TransactionLog.new and then log.log_transaction(transaction, account) Make a statement statement = Statement(log) and display it display = Display.new and display.print(statement) If you want to print the transactions just type account.print You'll see all the transactions, last one first.

Approach

My approach for this test was TDD. I first wrote a test, tried to pass it and when it passed, I tried to refactor the code written. Then I went on writing another test and so on, until I had all the requirements working. This Red/Green/Refactor cycle helped me get a good structure for this challenge.

Technical Specifications

I used Ruby for this challenge, Rspec for testing, Simplecov for the testcoverage and Rub0Cop as code analyzer

bank_tech_test's People

Contributors

zerga9 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.