football-manager 0.1.2 → 0.1.4

Sign up to get free protection for your applications and to get access to all the features.
data/README.md CHANGED
@@ -8,7 +8,7 @@ I am a tool to help you pick the fairest teams for your game
8
8
 
9
9
  ## HOW TO USE ME
10
10
 
11
- 1) Create a file with all your available players, including their names and skill level
11
+ 1) Create a file with all your available players, including their names and skill level (1-5)
12
12
 
13
13
  e.g. players.txt
14
14
 
@@ -25,6 +25,15 @@ e.g. players.txt
25
25
 
26
26
  3) Two fair team should now be output
27
27
 
28
+ Team A has 3 player and 11 points
29
+ Alan
30
+ Steve T
31
+ Tom
32
+ Team B has 3 player and 11 points
33
+ Jeff
34
+ Paul
35
+ Steve B
36
+
28
37
 
29
38
 
30
39
  I will randomise the teams to the best of my algorithmic ability!
data/bin/football-manager CHANGED
@@ -1,6 +1,5 @@
1
1
  #!/usr/bin/env ruby
2
2
 
3
- require 'ruby-debug'
4
3
  require 'optparse'
5
4
 
6
5
  require File.dirname(__FILE__) + '/../lib/football-manager'
@@ -6,6 +6,6 @@ def check_both_teams_are_equal(number_of_players, points)
6
6
  end
7
7
 
8
8
  def check_team_has_the_following(number_of_players, points)
9
- pattern = "Team (A|B) has #{number_of_players} player[s]? and #{points} points"
10
- assert_matching_output(pattern, all_output)
9
+ pattern = "Team (A|B) has #{number_of_players} player[s]? and #{points} points"
10
+ assert_matching_output(pattern, all_output)
11
11
  end
@@ -13,8 +13,8 @@ Gem::Specification.new do |s|
13
13
  ## If your rubyforge_project name is different, then edit it and comment out
14
14
  ## the sub! line in the Rakefile
15
15
  s.name = 'football-manager'
16
- s.version = '0.1.2'
17
- s.date = '2012-03-13'
16
+ s.version = '0.1.4'
17
+ s.date = '2012-03-17'
18
18
  s.rubyforge_project = 'football-manager'
19
19
 
20
20
  ## Make sure your summary is short. The description may be as long
@@ -1,5 +1,5 @@
1
1
  module FOOTBALLMANAGER
2
- VERSION = '0.1.2'
2
+ VERSION = '0.1.4'
3
3
  end
4
4
 
5
5
  require 'ruby-debug'
@@ -1,5 +1,5 @@
1
1
  module FootballManager
2
- module Game
2
+ class Game
3
3
  def self.pick_teams(player_data_reference)
4
4
  player_data = FootballManager::IOHelper.fetch_player_data(player_data_reference)
5
5
  players = FootballManager::PlayersCreator.create_players(player_data)
@@ -1,5 +1,5 @@
1
1
  module FootballManager
2
- module IOHelper
2
+ class IOHelper
3
3
  def self.fetch_player_data(player_data_reference)
4
4
  File.readlines(player_data_reference)
5
5
  end
@@ -7,22 +7,24 @@ module FootballManager
7
7
  def create_players(player_data)
8
8
  player_data.collect do |player|
9
9
  player =~ player_pattern
10
- self.player_match = Regexp.last_match
11
- FootballManager::Player.new(player_name, player_skill)
12
- end
10
+ if self.player_match = Regexp.last_match
11
+ FootballManager::Player.new(name, skill)
12
+ end
13
+ end.compact
13
14
  end
14
15
 
15
- def player_pattern
16
- /^\s*([a-zA-Z0-9]+\s?[a-zA-Z0-9]+)\s*,\s*([1-5]{1})\s*$/
17
- end
16
+ private
17
+ def player_pattern
18
+ /^\s*([a-zA-Z0-9]+\s?[a-zA-Z0-9]+)\s*,\s*([1-5]{1})\s*$/
19
+ end
18
20
 
19
- def player_name
20
- player_match.captures.first
21
- end
21
+ def name
22
+ player_match.captures.first
23
+ end
22
24
 
23
- def player_skill
24
- player_match.captures.last
25
- end
25
+ def skill
26
+ player_match.captures.last
27
+ end
26
28
  end
27
29
  end
28
30
  end
@@ -1,17 +1,9 @@
1
1
  module FootballManager
2
- module TeamPicker
2
+ class TeamPicker
3
3
  def self.calculate_fair_teams(players)
4
- # players_in_descending_order = players.sort { |a,b| b.skill <=> a.skill }
5
- players_in_descending_order = []
6
-
7
- 5.downto(1) do |i|
8
- players_in_descending_order <<
9
- players.select { |player| player.skill == i }.sort_by {rand}
10
- end
11
-
12
4
  team_a, team_b = FootballManager::Team.new, FootballManager::Team.new
13
5
 
14
- players_in_descending_order.flatten.partition do |player|
6
+ players_in_descending_order(players).each do |player|
15
7
  if team_a.empty? || team_a.points <= team_b.points
16
8
  team_a << player
17
9
  else
@@ -21,6 +13,13 @@ module FootballManager
21
13
 
22
14
  return [team_a, team_b]
23
15
  end
16
+
17
+ private
18
+ def self.players_in_descending_order(players)
19
+ 5.downto(1).collect do |i|
20
+ players.select { |player| player.skill == i }.sort_by {rand}
21
+ end.flatten!
22
+ end
24
23
  end
25
24
  end
26
25
 
@@ -1,5 +1,5 @@
1
1
  module FootballManager
2
- module TeamSheetCreator
2
+ class TeamSheetCreator
3
3
  def self.create_team_sheet(teams)
4
4
  teams.each do |team|
5
5
  puts "Team #{teams.first == team ? 'A' : 'B'} has #{team.size} player and #{team.points} points"
@@ -10,7 +10,7 @@ describe FootballManager::PlayersCreator do
10
10
  let(:player_2_name) { 'player 2' }
11
11
  let(:player_1_skill) { '5' }
12
12
  let(:player_2_skill) { '5' }
13
- let(:player_data) { [player_1, player_2] }
13
+ let(:player_data) { [player_1, player_2, ''] }
14
14
 
15
15
  it 'iterate through the player details, creating new players' do
16
16
  FootballManager::Player.should_receive(:new).once.with(player_1_name, player_1_skill)
@@ -4,10 +4,16 @@ describe FootballManager::TeamSheetCreator do
4
4
  subject { FootballManager::TeamSheetCreator }
5
5
 
6
6
  describe 'create_team_sheet' do
7
- let(:player_1) { double('player 1', :name => 'player 1', :skill => 1) }
8
- let(:player_2) { double('player 2', :name => 'player 2', :skill => 1) }
9
- let(:team_1) { double('team 1', :size => 1, :points => 5, :players => [player_1]) }
10
- let(:team_2) { double('team 2', :size => 1, :points => 5, :players => [player_2]) }
7
+ let(:player_1) { double('player 1', :name => 'player 1', :skill => 1) }
8
+ let(:player_2) { double('player 2', :name => 'player 2', :skill => 1) }
9
+ let(:team_1) { double( 'team 1',
10
+ :size => 1,
11
+ :points => 5,
12
+ :players_ordered_by_name => [player_1]) }
13
+ let(:team_2) { double( 'team 2',
14
+ :size => 1,
15
+ :points => 5,
16
+ :players_ordered_by_name => [player_2]) }
11
17
 
12
18
 
13
19
  it 'asks each team for their size' do
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: football-manager
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.2
4
+ version: 0.1.4
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-03-13 00:00:00.000000000Z
12
+ date: 2012-03-17 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: aruba
16
- requirement: &70137021946120 !ruby/object:Gem::Requirement
16
+ requirement: &70152889135460 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0.4'
22
22
  type: :development
23
23
  prerelease: false
24
- version_requirements: *70137021946120
24
+ version_requirements: *70152889135460
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: cucumber
27
- requirement: &70137021945240 !ruby/object:Gem::Requirement
27
+ requirement: &70152889134900 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '1.1'
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *70137021945240
35
+ version_requirements: *70152889134900
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: rake
38
- requirement: &70137021940580 !ruby/object:Gem::Requirement
38
+ requirement: &70152889134380 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,7 +43,7 @@ dependencies:
43
43
  version: '0'
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *70137021940580
46
+ version_requirements: *70152889134380
47
47
  description: Picks two teams fair based on player skill
48
48
  email: ionysis@gmail.com
49
49
  executables:
@@ -93,7 +93,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
93
93
  version: '0'
94
94
  segments:
95
95
  - 0
96
- hash: -1980237793795828249
96
+ hash: 4271657946246885275
97
97
  required_rubygems_version: !ruby/object:Gem::Requirement
98
98
  none: false
99
99
  requirements: