musicbrainz 0.3.1 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/README.rdoc CHANGED
@@ -1,4 +1,4 @@
1
- = MusicBrainz Web Service wrapper
1
+ = MusicBrainz Web Service wrapper {<img src="https://secure.travis-ci.org/magnolia-fan/musicbrainz.png"/>}[http://travis-ci.org/magnolia-fan/musicbrainz]
2
2
 
3
3
  === Installation
4
4
 
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.3.1
1
+ 0.4.0
@@ -15,12 +15,12 @@ module MusicBrainz
15
15
  5.times do
16
16
  begin
17
17
  response = open(url, "User-Agent" => "gem musicbrainz (https://github.com/magnolia-fan/musicbrainz) @ " + Socket.gethostname)
18
+ self.last_query_time = Time.now.to_f
18
19
  rescue => e
19
20
  p "MusicBrainz: 503"
20
21
  end
21
22
  break unless response.nil?
22
23
  end
23
- self.last_query_time = Time.now.to_f
24
24
  response
25
25
  end
26
26
 
@@ -6,7 +6,9 @@ module MusicBrainz
6
6
  def release_groups
7
7
  if @release_groups.nil? and not self.id.nil?
8
8
  @release_groups = []
9
- Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release-group/?artist=' + self.id)).css('release-group').each do |rg|
9
+ Nokogiri::XML(MusicBrainz.load(
10
+ 'http://musicbrainz.org/ws/2/release-group/?artist=' + self.id
11
+ )).css('release-group').each do |rg|
10
12
  @release_groups << MusicBrainz::ReleaseGroup.parse_xml(rg)
11
13
  end
12
14
  end
@@ -27,5 +29,36 @@ module MusicBrainz
27
29
  @artist.date_end = xml.css('artist > life-span > end').text unless xml.css('artist > life-span > end').empty?
28
30
  @artist
29
31
  end
32
+
33
+ def self.find_by_name name
34
+ matches = self.search name
35
+ matches.length.zero? ? nil : self.find(matches.first[:mbid])
36
+ end
37
+
38
+ def self.search name
39
+ artists = []
40
+ xml = Nokogiri::XML(MusicBrainz.load(
41
+ 'http://musicbrainz.org/ws/2/artist/?query='+ URI.escape(name).gsub(/\&/, '%26').gsub(/\?/, '%3F') +'~&limit=50'
42
+ ))
43
+ xml.css('artist-list > artist').each do |a|
44
+ artist = {
45
+ :name => a.first_element_child.text,
46
+ :weight => 0,
47
+ :desc => (a.css('disambiguation').text unless a.css('disambiguation').empty?),
48
+ :type => a.attr('type'),
49
+ :mbid => a.attr('id')
50
+ }
51
+ aliases = a.css('alias-list > alias').map{ |item| item.text }
52
+ if aliases.include? name
53
+ artist[:weight] += 20
54
+ elsif aliases.map{ |item| item.downcase }.include? name.downcase
55
+ artist[:weight] += 10
56
+ elsif aliases.map{ |item| item.downcase.gsub(/\s/, '') }.include? name.downcase.gsub(/\s/, '')
57
+ artist[:weight] += 5
58
+ end
59
+ artists << artist
60
+ end
61
+ artists.sort{ |a, b| b[:weight] <=> a[:weight] }.take(10)
62
+ end
30
63
  end
31
64
  end
@@ -6,7 +6,7 @@ module MusicBrainz
6
6
  def tracks
7
7
  if @tracks.nil? and not self.id.nil?
8
8
  @tracks = []
9
- Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/' + self.id + '?inc=recordings')).css('medium-list > medium > track-list > track').each do |r|
9
+ Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/' + self.id + '?inc=recordings&limit=100')).css('medium-list > medium > track-list > track').each do |r|
10
10
  @tracks << MusicBrainz::Track.parse_xml(r)
11
11
  end
12
12
  end
@@ -6,7 +6,7 @@ module MusicBrainz
6
6
  def releases
7
7
  if @releases.nil? and not self.id.nil?
8
8
  @releases = []
9
- Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/?release-group=' + self.id)).css('release').each do |r|
9
+ Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/?release-group=' + self.id + '&limit=100')).css('release').each do |r|
10
10
  @releases << MusicBrainz::Release.parse_xml(r)
11
11
  end
12
12
  end
@@ -3,7 +3,7 @@ module MusicBrainz
3
3
  attr_accessor :position, :recording_id, :title, :length
4
4
 
5
5
  def self.find mbid
6
- xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/recording/' + mbid))
6
+ xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/recording/' + mbid + '?limit=100'))
7
7
  self.parse_xml(xml) unless xml.nil?
8
8
  end
9
9
 
data/musicbrainz.gemspec CHANGED
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = %q{musicbrainz}
8
- s.version = "0.3.1"
8
+ s.version = "0.4.0"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = [%q{Gregory Eremin}]
12
- s.date = %q{2011-09-13}
12
+ s.date = %q{2011-09-14}
13
13
  s.description = %q{MusicBrainz Web Service wrapper with ActiveRecord-style models}
14
14
  s.email = %q{magnolia_fan@me.com}
15
15
  s.extra_rdoc_files = [
@@ -8,6 +8,17 @@ class TestMusicbrainz < Test::Unit::TestCase
8
8
  end
9
9
  end
10
10
 
11
+ should "search for artists by name" do
12
+ matches = MusicBrainz::Artist.search('Kasabian')
13
+ assert_operator(0, :<, matches.length)
14
+ assert_equal("Kasabian", matches.first[:name])
15
+ end
16
+
17
+ should "get correct artist by name" do
18
+ @artist = MusicBrainz::Artist.find_by_name('Kasabian')
19
+ assert_equal("69b39eab-6577-46a4-a9f5-817839092033", @artist.id)
20
+ end
21
+
11
22
  setup do
12
23
  @artist = MusicBrainz::Artist.find('69b39eab-6577-46a4-a9f5-817839092033')
13
24
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: musicbrainz
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.1
4
+ version: 0.4.0
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: 2011-09-13 00:00:00.000000000Z
12
+ date: 2011-09-14 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: nokogiri
16
- requirement: &2152915760 !ruby/object:Gem::Requirement
16
+ requirement: &2153490500 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *2152915760
24
+ version_requirements: *2153490500
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: shoulda
27
- requirement: &2152914720 !ruby/object:Gem::Requirement
27
+ requirement: &2153489260 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *2152914720
35
+ version_requirements: *2153489260
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: bundler
38
- requirement: &2152913500 !ruby/object:Gem::Requirement
38
+ requirement: &2153467600 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 1.0.0
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *2152913500
46
+ version_requirements: *2153467600
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: jeweler
49
- requirement: &2152912280 !ruby/object:Gem::Requirement
49
+ requirement: &2153466800 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 1.6.4
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *2152912280
57
+ version_requirements: *2153466800
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: rcov
60
- requirement: &2152911400 !ruby/object:Gem::Requirement
60
+ requirement: &2153465500 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *2152911400
68
+ version_requirements: *2153465500
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: rdoc
71
- requirement: &2152910500 !ruby/object:Gem::Requirement
71
+ requirement: &2153464900 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,7 +76,7 @@ dependencies:
76
76
  version: '0'
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *2152910500
79
+ version_requirements: *2153464900
80
80
  description: MusicBrainz Web Service wrapper with ActiveRecord-style models
81
81
  email: magnolia_fan@me.com
82
82
  executables: []
@@ -116,7 +116,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
116
116
  version: '0'
117
117
  segments:
118
118
  - 0
119
- hash: -2577539182600304667
119
+ hash: -2702220955620971085
120
120
  required_rubygems_version: !ruby/object:Gem::Requirement
121
121
  none: false
122
122
  requirements: