-
-
Notifications
You must be signed in to change notification settings - Fork 519
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Luhn with generator #559
Luhn with generator #559
Changes from 4 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
1 |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,35 +1,30 @@ | ||
class Luhn | ||
def self.create(number) | ||
test_number = number * 10 | ||
luhn = Luhn.new(test_number) | ||
return test_number if luhn.valid? | ||
test_number + 10 - (luhn.checksum % 10) | ||
end | ||
DOUBLE = [0, 2, 4, 6, 8, 1, 3, 5, 7, 9] | ||
DOUBLE.freeze | ||
|
||
attr_reader :number | ||
def initialize(number) | ||
@number = number | ||
def self.valid?(string) | ||
Luhn.new(string).valid? | ||
end | ||
|
||
def addends | ||
numbers = [] | ||
number.to_s.reverse.split('').map(&:to_i).each_with_index do |n, i| | ||
if i % 2 == 0 | ||
numbers << n | ||
else | ||
value = n * 2 | ||
value -= 9 if value > 9 | ||
numbers << value | ||
end | ||
end | ||
numbers.reverse | ||
def initialize(string) | ||
@string = string.tr(' ', '') | ||
end | ||
|
||
def checksum | ||
addends.inject(0, :+) | ||
@string. | ||
reverse.each_char.with_index. | ||
reduce(0) {|sum, (c, i)| sum + (i.odd? ? DOUBLE[c.to_i] : c.to_i) } | ||
end | ||
|
||
def valid? | ||
checksum % 10 == 0 | ||
clean? && (checksum % 10).zero? | ||
end | ||
|
||
def clean? | ||
@string.match(/^\d{2,}$/) | ||
end | ||
end | ||
|
||
module BookKeeping | ||
VERSION = 1 | ||
end |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
#!/usr/bin/env ruby | ||
gem 'minitest', '>= 5.0.0' | ||
require 'minitest/autorun' | ||
require_relative 'luhn' | ||
|
||
# Common test data version: <%= abbreviated_commit_hash %> | ||
class LuhnTest < Minitest::Test<% test_cases.each do |test_case| %> | ||
def <%= test_case.name %> | ||
<%= test_case.skipped %> | ||
<%= test_case.work_load %> | ||
end | ||
<% end %> | ||
<%= IO.read(XRUBY_LIB + '/bookkeeping.md') %> | ||
def test_bookkeeping | ||
skip | ||
assert_equal <%= version %>, BookKeeping::VERSION | ||
end | ||
end |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
require 'exercise_cases' | ||
|
||
class LuhnCase < OpenStruct | ||
def name | ||
'test_%s' % description.tr('- ', '__') | ||
end | ||
|
||
def work_load | ||
%Q(#{assertion} Luhn.valid?("#{input}")) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
This will work, but it's a good habit to use Nice usage of There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good idea! |
||
end | ||
|
||
def skipped | ||
index.zero? ? '# skip' : 'skip' | ||
end | ||
|
||
private | ||
|
||
def assertion | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This can be made private as it is only needed by |
||
expected ? 'assert' : 'refute' | ||
end | ||
end | ||
|
||
LuhnCases = proc do |data| | ||
JSON.parse(data)['cases'].map.with_index do |row, i| | ||
LuhnCase.new(row.merge('index' => i)) | ||
end | ||
end |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should be
workload
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've updated the documentation to help clarify this: #560
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a style guide somewhere (other than the README)? Because some of the exercises use
work_load
and others useworkload
. In fact, as long as it is the same in bothexample.tt
and<exercise>_cases.rb
it should work fine.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No, just the README.
I've made a PR to rename the old occurrences to try and clear this up: #561