halo_stats 1.0.1 → 1.0.3

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: c22117b15edd33021bee911128a03ef42d24257c
4
- data.tar.gz: cd264f2f320648116794c1d6d716cb3a7cdd04f0
3
+ metadata.gz: 0804dfa25b49e6110de9567c8d5b5fb7cca0eb4e
4
+ data.tar.gz: 6e2b31bfdb25dc986d2c41dc6835ea572e26620f
5
5
  SHA512:
6
- metadata.gz: 1c323666a1fbfb358d9e626d832e379c34184cadc72c25c6b20523c5034c6009c690e1d51089d99762fa7533256104f7ddb186b14128b0664b21d1066d4922e6
7
- data.tar.gz: 95eb7de1124ae8385dc7f3dca3804589c9d6f222da4cfc1506397574827e034d7d98225bd24b09971d908e6efe7b003c365f972f668890b7e51a252f2cc64fcc
6
+ metadata.gz: b6b96c79c8fdc8deed179d2b5762c9ce4956e7e5c38fb23b6995d0091e8c2c426a9ba2fdd227dba7fa90c0f097dc95bd2233315e4d3953f890fe58e1a806e5f9
7
+ data.tar.gz: 05ecadddd4ba799110119732ed2561b581146d6e008d940730ce4836b761a8f690bfab3ca2d366a65790d3fd0fcd4de0c36b549feb0152a8f68ff0b2792c7ad8
data/Gemfile CHANGED
@@ -3,7 +3,7 @@ source 'https://rubygems.org'
3
3
  # Specify your gem's dependencies in takeout.gemspec
4
4
  gemspec
5
5
 
6
- gem 'takeout', "1.0.2"
6
+ gem 'takeout', "1.0.4"
7
7
 
8
8
  group :development do
9
9
  gem "guard", "2.12.5", require: false
@@ -0,0 +1,57 @@
1
+ # HaloStats
2
+ [![Gem Version](https://badge.fury.io/rb/halo_stats.svg)](http://badge.fury.io/rb/halo_stats)
3
+ [![Code Climate](https://codeclimate.com/github/kylegrantlucas/halo_stats/badges/gpa.svg)](https://codeclimate.com/github/kylegrantlucas/halo_stats)
4
+ [![Test Coverage](https://codeclimate.com/github/kylegrantlucas/halo_stats/badges/coverage.svg)](https://codeclimate.com/github/kylegrantlucas/halo_stats/coverage)
5
+ [![Circle CI](https://circleci.com/gh/kylegrantlucas/halo_stats/tree/master.svg?style=shield)](https://circleci.com/gh/kylegrantlucas/halo_stats/tree/master)
6
+ [![Inline docs](http://inch-ci.org/github/kylegrantlucas/halo_stats.svg?branch=master&style=shields)](http://inch-ci.org/github/kylegrantlucas/halo_stats)
7
+ [![Join the chat at https://gitter.im/kylegrantlucas/halo_stats](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/kylegrantlucas/halo_stats?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
8
+ [![Analytics](https://ga-beacon.appspot.com/UA-62799576-1/kylegrantlucas/halo_stats?pixel)](https://github.com/igrigorik/ga-beacon)
9
+
10
+ A ruby gem wrapper for the Halo 5 API.
11
+
12
+ ## Requirements
13
+
14
+ All versions of MRI 1.9.3+ and up are supported (and tested via CircleCI), the gem is currently unsupported on JRuby, MRI 1.8-1.9.2, and Rubinus.
15
+ Support of these platforms is a future goal for the project.
16
+
17
+ ## Installation
18
+
19
+ Add this line to your application's Gemfile:
20
+
21
+ gem 'halo_stats'
22
+
23
+ And then execute:
24
+
25
+ $ bundle
26
+
27
+ Or install it yourself as:
28
+
29
+ $ gem install halo_stats
30
+
31
+ ## Usage
32
+
33
+ ### Quick Use
34
+
35
+ The first step is to instantiate some clients for the data we would like to grab:
36
+
37
+ stats_client = Halo::StatsClient.new(api_key: 'APIKEY')
38
+ profile_client = Halo::StatsClient.new(api_key: 'APIKEY')
39
+ metadata_client = Halo::StatsClient.new(api_key: 'APIKEY')
40
+
41
+ From here you can begin calling your any api methods!
42
+ So an example of call flow would be:
43
+
44
+ matches_response = stats_client.get_matches('GAMERTAG')
45
+ arena_match_response = stats_client.get_arena_carnage_report(match_response.first["Id"]["MatchId"])
46
+ game_variant_response = metadata_client.get_game_variants(match_response["GameVariantId"])
47
+ spartan_image_url = profile_client.get_spartan_image('GAMERTAG')
48
+
49
+ Results are returned as parsed ruby objects (generally a hash or an array of hashes).
50
+
51
+ ## Contributing
52
+
53
+ 1. Fork it ( https://github.com/kylegrantlucas/halo_stats/fork )
54
+ 2. Create your feature branch (`git checkout -b my-new-feature`)
55
+ 3. Commit your changes (`git commit -am 'Add some feature'`)
56
+ 4. Push to the branch (`git push origin my-new-feature`)
57
+ 5. Create a new Pull Request
@@ -0,0 +1,28 @@
1
+ notify:
2
+ webhooks:
3
+ # A list of hook hashes, containing the url field
4
+ # gitter hook
5
+ - url: https://webhooks.gitter.im/e/c114cd659f05cf6ad19f
6
+
7
+ dependencies:
8
+ override:
9
+ - >
10
+ case $CIRCLE_NODE_INDEX in
11
+ 0)
12
+ rvm-exec 1.9.3-p0 bash -c "bundle check --path=vendor/bundle || bundle install --path=vendor/bundle"
13
+ ;;
14
+ 1)
15
+ rvm-exec 2.0.0-p0 bash -c "bundle check --path=vendor/bundle || bundle install --path=vendor/bundle"
16
+ ;;
17
+ 2)
18
+ rvm-exec 2.2.0 bash -c "bundle check --path=vendor/bundle || bundle install --path=vendor/bundle"
19
+ ;;
20
+ 3)
21
+ rvm-exec 2.1.0 bash -c "bundle check --path=vendor/bundle || bundle install --path=vendor/bundle"
22
+ ;;
23
+ esac
24
+
25
+ test:
26
+ override:
27
+ - case $CIRCLE_NODE_INDEX in 0) rvm-exec 1.9.3-p0 bundle exec rspec ;; 1) rvm-exec 2.0.0-p0 bundle exec rspec ;; 2) rvm-exec 2.2.0 bundle exec rspec ;; 3) rvm-exec 2.1.0 bundle exec rspec ;; esac:
28
+ parallel: true
@@ -21,7 +21,7 @@ Gem::Specification.new do |spec|
21
21
 
22
22
  spec.add_development_dependency "bundler", "~> 1.6"
23
23
  spec.add_development_dependency "rake"
24
- spec.add_runtime_dependency "takeout", "~> 1.0.2"
24
+ spec.add_runtime_dependency "takeout", "~> 1.0.4"
25
25
  spec.add_development_dependency "rspec"
26
26
  spec.add_development_dependency "sinatra"
27
27
  spec.add_development_dependency "webmock"
@@ -2,8 +2,9 @@ module HaloStats
2
2
  class Stats
3
3
  require 'takeout'
4
4
  attr_accessor :stats_client
5
-
6
5
 
6
+ GAME_TYPES = [:arena, :warzone, :campaign, :custom_game]
7
+
7
8
  def initialize(options={})
8
9
  title = 'h5'
9
10
  key = options[:api_key]
@@ -11,7 +12,7 @@ module HaloStats
11
12
  stats_schemas = { get: {
12
13
  player_matches: "#{stats_prefix}/players/{{gamertag}}/matches",
13
14
  arena_matches: "#{stats_prefix}/arena/matches/{{id}}",
14
- campign_matches: "#{stats_prefix}/campaign/matches/{{id}}",
15
+ campaign_matches: "#{stats_prefix}/campaign/matches/{{id}}",
15
16
  warzone_matches: "#{stats_prefix}/warzone/matches/{{id}}",
16
17
  custom_game_matches: "#{stats_prefix}/custom/matches/{{id}}",
17
18
  arena_service_record: "#{stats_prefix}/servicerecords/arena",
@@ -23,6 +24,9 @@ module HaloStats
23
24
 
24
25
  self.stats_client = Takeout::Client.new(uri: "www.haloapi.com", schemas: stats_schemas, headers: {'Ocp-Apim-Subscription-Key' => key}, ssl: true)
25
26
 
27
+ generate_carnage_report_methods
28
+ generate_service_record_methods
29
+
26
30
  return self
27
31
  end
28
32
 
@@ -30,36 +34,20 @@ module HaloStats
30
34
  return stats_client.get_player_matches(gamertag: gamertag).body
31
35
  end
32
36
 
33
- def get_arena_carnage_report(id)
34
- return stats_client.get_arena_matches(id: id).body
35
- end
36
-
37
- def get_campaign_carnage_report(id)
38
- return stats_client.get_campaign_matches(id: id).body
39
- end
40
-
41
- def get_warzone_carnage_report(id)
42
- return stats_client.get_warzone_matches(id: id).body
43
- end
44
-
45
- def custom_game_carnage_report(id)
46
- return stats_client.get_custom_game_matches(id: id).body
47
- end
48
-
49
- def get_arena_service_record(gamertags)
50
- return stats_client.get_arena_service_record(players: [gamertags].flatten(1).join(',')).body
51
- end
52
-
53
- def get_campaign_service_record(gamertags)
54
- return stats_client.get_campaign_service_record(players: [gamertags].flatten(1).join(',')).body
55
- end
56
-
57
- def get_custom_game_service_record(gamertags)
58
- return stats_client.get_custom_game_service_record(players: [gamertags].flatten(1).join(',')).body
37
+ def generate_carnage_report_methods
38
+ GAME_TYPES.each do |game_type|
39
+ self.define_singleton_method("get_#{game_type.to_s}_carnage_report") do |id, &block|
40
+ return stats_client.send("get_#{game_type.to_s}_matches".to_sym, {id: id}).body
41
+ end
42
+ end
59
43
  end
60
44
 
61
- def get_warzone_service_record(gamertags)
62
- return stats_client.get_warzone_service_record(players: [gamertags].flatten(1).join(',')).body
45
+ def generate_service_record_methods
46
+ GAME_TYPES.each do |game_type|
47
+ self.define_singleton_method("get_#{game_type.to_s}_service_record") do |gamertags, &block|
48
+ return stats_client.send("get_#{game_type.to_s}_service_record".to_sym, {players: [gamertags].flatten(1).join(',')}).body
49
+ end
50
+ end
63
51
  end
64
52
  end
65
53
  end
@@ -1,3 +1,3 @@
1
1
  module HaloStats
2
- VERSION = "1.0.1"
2
+ VERSION = "1.0.3"
3
3
  end
Binary file
@@ -0,0 +1,91 @@
1
+ require 'spec_helper'
2
+
3
+ describe HaloStats::Metadata do
4
+ let (:metadata_client) {HaloStats::Metadata.new(api_key: 'fakekey')}
5
+
6
+ context 'get' do
7
+ it 'returns a hash for get_campaign_missions' do
8
+ expect(metadata_client.get_campaign_missions).to be_a(Array)
9
+ end
10
+
11
+ it 'returns a hash for get_commendations' do
12
+ expect(metadata_client.get_commendations).to be_a(Array)
13
+ end
14
+
15
+ it 'returns a hash for get_csr_designations' do
16
+ expect(metadata_client.get_csr_designations).to be_a(Array)
17
+ end
18
+
19
+ it 'returns a hash for get_enemies' do
20
+ expect(metadata_client.get_enemies).to be_a(Array)
21
+ end
22
+
23
+ it 'returns a hash for get_flexible_stats' do
24
+ expect(metadata_client.get_flexible_stats).to be_a(Array)
25
+ end
26
+
27
+ it 'returns a hash for get_game_base_variants' do
28
+ expect(metadata_client.get_game_base_variants).to be_a(Array)
29
+ end
30
+
31
+ it 'returns a hash for get_game_variants' do
32
+ expect(metadata_client.get_game_variants(1)).to be_a(Array)
33
+ end
34
+
35
+ it 'returns a hash for get_impulses' do
36
+ expect(metadata_client.get_impulses).to be_a(Array)
37
+ end
38
+
39
+ it 'returns a hash for get_map_variants' do
40
+ expect(metadata_client.get_map_variants(1)).to be_a(Array)
41
+ end
42
+
43
+ it 'returns a hash for get_maps' do
44
+ expect(metadata_client.get_maps).to be_a(Array)
45
+ end
46
+
47
+ it 'returns a hash for get_medals' do
48
+ expect(metadata_client.get_medals).to be_a(Array)
49
+ end
50
+
51
+ it 'returns a hash for get_playlists' do
52
+ expect(metadata_client.get_playlists).to be_a(Array)
53
+ end
54
+
55
+ it 'returns a hash for get_requisition_packs' do
56
+ expect(metadata_client.get_requisition_packs(1)).to be_a(Array)
57
+ end
58
+
59
+ it 'returns a hash for get_requisitions' do
60
+ expect(metadata_client.get_requisitions(1)).to be_a(Array)
61
+ end
62
+
63
+ it 'returns a hash for get_seasons' do
64
+ expect(metadata_client.get_seasons).to be_a(Array)
65
+ end
66
+
67
+ it 'returns a hash for get_skulls' do
68
+ expect(metadata_client.get_skulls).to be_a(Array)
69
+ end
70
+
71
+ it 'returns a hash for get_spartan_ranks' do
72
+ expect(metadata_client.get_spartan_ranks).to be_a(Array)
73
+ end
74
+
75
+ it 'returns a hash for get_team_colors' do
76
+ expect(metadata_client.get_team_colors).to be_a(Array)
77
+ end
78
+
79
+ it 'returns a hash for get_vehicles' do
80
+ expect(metadata_client.get_vehicles).to be_a(Array)
81
+ end
82
+
83
+ it 'returns a hash for get_weapons' do
84
+ expect(metadata_client.get_weapons).to be_a(Array)
85
+ end
86
+
87
+ it 'returns a hash for get_weapons' do
88
+ expect(metadata_client.get_weapons).to be_a(Array)
89
+ end
90
+ end
91
+ end
@@ -0,0 +1,15 @@
1
+ require 'spec_helper'
2
+
3
+ describe HaloStats::Profile do
4
+ let (:profile_client) {HaloStats::Profile.new(api_key: 'fakekey')}
5
+
6
+ context 'get' do
7
+ it 'returns a string for get_emblem' do
8
+ expect(profile_client.get_emblem('faketag')).to be_an(String)
9
+ end
10
+
11
+ it 'returns a string for get_spartan_image' do
12
+ expect(profile_client.get_spartan_image('faketag')).to be_an(String)
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,104 @@
1
+ require "codeclimate-test-reporter"
2
+ CodeClimate::TestReporter.start
3
+ require 'bundler/setup'
4
+ Bundler.setup
5
+ require 'halo_stats'
6
+ require 'webmock/rspec'
7
+ WebMock.disable_net_connect!(:allow => "codeclimate.com")
8
+
9
+ Dir["./spec/support/**/*.rb"].sort.each { |f| require f}
10
+ # This file was generated by the `rspec --init` command. Conventionally, all
11
+ # specs live under a `spec` directory, which RSpec adds to the `$LOAD_PATH`.
12
+ # The generated `.rspec` file contains `--require spec_helper` which will cause
13
+ # this file to always be loaded, without a need to explicitly require it in any
14
+ # files.
15
+ #
16
+ # Given that it is always loaded, you are encouraged to keep this file as
17
+ # light-weight as possible. Requiring heavyweight dependencies from this file
18
+ # will add to the boot time of your test suite on EVERY test run, even for an
19
+ # individual file that may not need all of that loaded. Instead, consider making
20
+ # a separate helper file that requires the additional dependencies and performs
21
+ # the additional setup, and require it from the spec files that actually need
22
+ # it.
23
+ #
24
+ # The `.rspec` file also contains a few flags that are not defaults but that
25
+ # users commonly want.
26
+ #
27
+ # See http://rubydoc.info/gems/rspec-core/RSpec/Core/Configuration
28
+ RSpec.configure do |config|
29
+ # rspec-expectations config goes here. You can use an alternate
30
+ # assertion/expectation library such as wrong or the stdlib/minitest
31
+ # assertions if you prefer.
32
+ config.expect_with :rspec do |expectations|
33
+ # This option will default to `true` in RSpec 4. It makes the `description`
34
+ # and `failure_message` of custom matchers include text for helper methods
35
+ # defined using `chain`, e.g.:
36
+ # be_bigger_than(2).and_smaller_than(4).description
37
+ # # => "be bigger than 2 and smaller than 4"
38
+ # ...rather than:
39
+ # # => "be bigger than 2"
40
+ expectations.include_chain_clauses_in_custom_matcher_descriptions = true
41
+ end
42
+
43
+ # rspec-mocks config goes here. You can use an alternate test double
44
+ # library (such as bogus or mocha) by changing the `mock_with` option here.
45
+ config.mock_with :rspec do |mocks|
46
+ # Prevents you from mocking or stubbing a method that does not exist on
47
+ # a real object. This is generally recommended, and will default to
48
+ # `true` in RSpec 4.
49
+ mocks.verify_partial_doubles = true
50
+ end
51
+
52
+ # The settings below are suggested to provide a good initial experience
53
+ # with RSpec, but feel free to customize to your heart's content.
54
+ =begin
55
+ # These two settings work together to allow you to limit a spec run
56
+ # to individual examples or groups you care about by tagging them with
57
+ # `:focus` metadata. When nothing is tagged with `:focus`, all examples
58
+ # get run.
59
+ config.filter_run :focus
60
+ config.run_all_when_everything_filtered = true
61
+
62
+ # Limits the available syntax to the non-monkey patched syntax that is
63
+ # recommended. For more details, see:
64
+ # - http://myronmars.to/n/dev-blog/2012/06/rspecs-new-expectation-syntax
65
+ # - http://teaisaweso.me/blog/2013/05/27/rspecs-new-message-expectation-syntax/
66
+ # - http://myronmars.to/n/dev-blog/2014/05/notable-changes-in-rspec-3#new__config_option_to_disable_rspeccore_monkey_patching
67
+ config.disable_monkey_patching!
68
+
69
+ # This setting enables warnings. It's recommended, but in some cases may
70
+ # be too noisy due to issues in dependencies.
71
+ config.warnings = true
72
+
73
+ # Many RSpec users commonly either run the entire suite or an individual
74
+ # file, and it's useful to allow more verbose output when running an
75
+ # individual spec file.
76
+ if config.files_to_run.one?
77
+ # Use the documentation formatter for detailed output,
78
+ # unless a formatter has already been configured
79
+ # (e.g. via a command-line flag).
80
+ config.default_formatter = 'doc'
81
+ end
82
+
83
+ # Print the 10 slowest examples and example groups at the
84
+ # end of the spec run, to help surface which specs are running
85
+ # particularly slow.
86
+ config.profile_examples = 10
87
+
88
+ # Run specs in random order to surface order dependencies. If you find an
89
+ # order dependency and want to debug it, you can fix the order by providing
90
+ # the seed, which is printed after each run.
91
+ # --seed 1234
92
+ config.order = :random
93
+
94
+ # Seed global randomization in this process using the `--seed` CLI option.
95
+ # Setting this allows you to use `--seed` to deterministically reproduce
96
+ # test failures related to randomization by passing the same `--seed` value
97
+ # as the one that triggered the failure.
98
+ Kernel.srand config.seed
99
+ =end
100
+
101
+ config.before(:each) do
102
+ stub_request(:any, /haloapi.com/).to_rack(FakeTestApi)
103
+ end
104
+ end
@@ -0,0 +1,43 @@
1
+ require 'spec_helper'
2
+
3
+ describe HaloStats::Stats do
4
+ let (:stats_client) {HaloStats::Stats.new(api_key: 'fakekey')}
5
+
6
+ context 'get' do
7
+ it 'returns a hash for get_matches' do
8
+ expect(stats_client.get_matches('faketag')).to be_an(Hash)
9
+ end
10
+
11
+ it 'returns a hash for get_arena_carnage_report' do
12
+ expect(stats_client.get_arena_carnage_report(1)).to be_an(Hash)
13
+ end
14
+
15
+ it 'returns a hash for get_campaign_carnage_report' do
16
+ expect(stats_client.get_campaign_carnage_report(1)).to be_an(Hash)
17
+ end
18
+
19
+ it 'returns a hash for get_warzone_carnage_report' do
20
+ expect(stats_client.get_warzone_carnage_report(1)).to be_an(Hash)
21
+ end
22
+
23
+ it 'returns a hash for get_custom_game_carnage_report' do
24
+ expect(stats_client.get_custom_game_carnage_report(1)).to be_an(Hash)
25
+ end
26
+
27
+ it 'returns a hash for get_arena_service_record' do
28
+ expect(stats_client.get_arena_service_record('faketag')).to be_an(Hash)
29
+ end
30
+
31
+ it 'returns a hash for get_warzone_service_record' do
32
+ expect(stats_client.get_warzone_service_record('faketag')).to be_an(Hash)
33
+ end
34
+
35
+ it 'returns a hash for get_campaign_service_record' do
36
+ expect(stats_client.get_campaign_service_record('faketag')).to be_an(Hash)
37
+ end
38
+
39
+ it 'returns a hash for get_custom_game_service_record' do
40
+ expect(stats_client.get_custom_game_service_record('faketag')).to be_an(Hash)
41
+ end
42
+ end
43
+ end
Binary file
@@ -0,0 +1,56 @@
1
+ require 'sinatra/base'
2
+
3
+ class FakeTestApi < Sinatra::Base
4
+ REQUEST_TYPES = [:get]
5
+ #
6
+ # /stats endpoints
7
+ #
8
+ get('/stats/h5/players/faketag/matches') {json_response 200, 'matches.json'}
9
+ get('/stats/h5/arena/matches/1') {json_response 200, 'matches.json'}
10
+ get('/stats/h5/campaign/matches/1') {json_response 200, 'matches.json'}
11
+ get('/stats/h5/custom/matches/1') {json_response 200, 'matches.json'}
12
+ get('/stats/h5/warzone/matches/1') {json_response 200, 'matches.json'}
13
+ get('/stats/h5/arena/matches/1') {json_response 200, 'matches.json'}
14
+ get('/stats/h5/servicerecords/arena') {json_response 200, 'matches.json'}
15
+ get('/stats/h5/servicerecords/custom') {json_response 200, 'matches.json'}
16
+ get('/stats/h5/servicerecords/campaign') {json_response 200, 'matches.json'}
17
+ get('/stats/h5/servicerecords/warzone') {json_response 200, 'matches.json'}
18
+
19
+ #
20
+ # /profile endpoints
21
+ #
22
+ get('/profile/h5/profiles/faketag/emblem') {json_response 302, 'posts.json'}
23
+ get('/profile/h5/profiles/faketag/spartan') {json_response 302, 'posts.json'}
24
+
25
+ #
26
+ # /metadata endpoints
27
+ #
28
+ get('/metadata/h5/metadata/campaign-missions') {json_response 200, 'posts.json'}
29
+ get('/metadata/h5/metadata/commendations') {json_response 200, 'posts.json'}
30
+ get('/metadata/h5/metadata/csr-designations') {json_response 200, 'posts.json'}
31
+ get('/metadata/h5/metadata/enemies') {json_response 200, 'posts.json'}
32
+ get('/metadata/h5/metadata/flexible-stats') {json_response 200, 'posts.json'}
33
+ get('/metadata/h5/metadata/game-base-variants') {json_response 200, 'posts.json'}
34
+ get('/metadata/h5/metadata/game-variants/1') {json_response 200, 'posts.json'}
35
+ get('/metadata/h5/metadata/impulses') {json_response 200, 'posts.json'}
36
+ get('/metadata/h5/metadata/map-variants/1') {json_response 200, 'posts.json'}
37
+ get('/metadata/h5/metadata/maps') {json_response 200, 'posts.json'}
38
+ get('/metadata/h5/metadata/medals') {json_response 200, 'posts.json'}
39
+ get('/metadata/h5/metadata/playlists') {json_response 200, 'posts.json'}
40
+ get('/metadata/h5/metadata/requisition-packs/1') {json_response 200, 'posts.json'}
41
+ get('/metadata/h5/metadata/requisitions/1') {json_response 200, 'posts.json'}
42
+ get('/metadata/h5/metadata/seasons') {json_response 200, 'posts.json'}
43
+ get('/metadata/h5/metadata/skulls') {json_response 200, 'posts.json'}
44
+ get('/metadata/h5/metadata/spartan-ranks') {json_response 200, 'posts.json'}
45
+ get('/metadata/h5/metadata/team-colors') {json_response 200, 'posts.json'}
46
+ get('/metadata/h5/metadata/vehicles') {json_response 200, 'posts.json'}
47
+ get('/metadata/h5/metadata/weapons') {json_response 200, 'posts.json'}
48
+
49
+ private
50
+
51
+ def json_response(response_code, file_name)
52
+ content_type :json
53
+ status response_code
54
+ File.open(File.dirname(__FILE__) + '/fixtures/' + file_name, 'rb').read if file_name
55
+ end
56
+ end
@@ -0,0 +1,3 @@
1
+ {
2
+ "id": 1
3
+ }
@@ -0,0 +1,8 @@
1
+ [
2
+ {
3
+ "id": 1
4
+ },
5
+ {
6
+ "id": 2
7
+ }
8
+ ]
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: halo_stats
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.1
4
+ version: 1.0.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - Kyle Lucas
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2016-02-06 00:00:00.000000000 Z
11
+ date: 2016-02-07 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -44,14 +44,14 @@ dependencies:
44
44
  requirements:
45
45
  - - "~>"
46
46
  - !ruby/object:Gem::Version
47
- version: 1.0.2
47
+ version: 1.0.4
48
48
  type: :runtime
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
52
  - - "~>"
53
53
  - !ruby/object:Gem::Version
54
- version: 1.0.2
54
+ version: 1.0.4
55
55
  - !ruby/object:Gem::Dependency
56
56
  name: rspec
57
57
  requirement: !ruby/object:Gem::Requirement
@@ -118,14 +118,24 @@ files:
118
118
  - ".gitignore"
119
119
  - Gemfile
120
120
  - Guardfile
121
- - README
121
+ - README.md
122
122
  - Rakefile
123
+ - circle.yml
123
124
  - halo_stats.gemspec
124
125
  - lib/halo_stats.rb
125
126
  - lib/halo_stats/metadata.rb
126
127
  - lib/halo_stats/profile.rb
127
128
  - lib/halo_stats/stats.rb
128
129
  - lib/halo_stats/version.rb
130
+ - spec/.DS_Store
131
+ - spec/metadata_spec.rb
132
+ - spec/profile_spec.rb
133
+ - spec/spec_helper.rb
134
+ - spec/stats_spec.rb
135
+ - spec/support/.DS_Store
136
+ - spec/support/fake_test_api.rb
137
+ - spec/support/fixtures/matches.json
138
+ - spec/support/fixtures/posts.json
129
139
  homepage: http://github.com/kylegrantlucas/halo_stats
130
140
  licenses:
131
141
  - MIT
@@ -150,5 +160,14 @@ rubygems_version: 2.2.2
150
160
  signing_key:
151
161
  specification_version: 4
152
162
  summary: A stats gem for Halo 5.
153
- test_files: []
163
+ test_files:
164
+ - spec/.DS_Store
165
+ - spec/metadata_spec.rb
166
+ - spec/profile_spec.rb
167
+ - spec/spec_helper.rb
168
+ - spec/stats_spec.rb
169
+ - spec/support/.DS_Store
170
+ - spec/support/fake_test_api.rb
171
+ - spec/support/fixtures/matches.json
172
+ - spec/support/fixtures/posts.json
154
173
  has_rdoc:
data/README DELETED
File without changes