Skip to content

Commit

Permalink
Sync: merge releases 2.2.3 and 2.2.4 from ncbo (#3)
Browse files Browse the repository at this point in the history
* Configure a PURL prefix for test purposes

* Fix some RuboCop warnings

* Add faraday-follow_redirects gem

* Fix some RuboCop warnings

* Add unit tests for the purl method

* Configure a PURL host

* Modify purl method to check class IDs for purl_host

Resolves #28

* Provide default value for purl_host

* Fix some RuboCop warnings

* Move gem version to a module

* Move faraday-follow_redirects to a dev dependency

* Add require_relative for version

* Bump version from 2.2.2 to 2.2.3

* Replace test-unit with minitest

* Modify unit test code to use Minitest

* Fix some RuboCop warnings

* Use more appropriate assertions

* Bump version from 2.2.3 to 2.2.4

* Remove Ruby 2.7 and add 3.1 to test matrix
  • Loading branch information
jvendetti authored Jan 8, 2024
1 parent 9d47f83 commit 0feaef1
Show file tree
Hide file tree
Showing 12 changed files with 126 additions and 42 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ruby.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ jobs:
strategy:
fail-fast: false
matrix:
ruby-version: ['2.7', '3.0']
ruby-version: ['3.0', '3.1']
steps:
- uses: actions/checkout@v3
- name: Set up Ruby
Expand Down
5 changes: 3 additions & 2 deletions Gemfile
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
# frozen_string_literal: true

source 'https://rubygems.org'

gemspec

gem 'pry'
gem 'rake'
gem 'rubocop', '~> 1.43'
gem 'pry'
gem 'test-unit'
10 changes: 5 additions & 5 deletions Gemfile.lock
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
PATH
remote: .
specs:
ontologies_api_client (2.2.2)
ontologies_api_client (2.2.4)
activesupport (= 6.1.7.3)
addressable (~> 2.8)
excon
Expand Down Expand Up @@ -34,6 +34,8 @@ GEM
faraday-excon (2.1.0)
excon (>= 0.27.4)
faraday (~> 2.0)
faraday-follow_redirects (0.3.0)
faraday (>= 1, < 3)
faraday-multipart (1.0.4)
multipart-post (~> 2)
faraday-net_http (3.0.2)
Expand All @@ -49,7 +51,6 @@ GEM
parallel (1.22.1)
parser (3.2.0.0)
ast (~> 2.4.1)
power_assert (2.0.3)
pry (0.14.2)
coderay (~> 1.1)
method_source (~> 1.0)
Expand All @@ -73,8 +74,6 @@ GEM
ruby-progressbar (1.11.0)
ruby2_keywords (0.0.5)
spawnling (2.1.5)
test-unit (3.5.7)
power_assert
tzinfo (2.0.6)
concurrent-ruby (~> 1.0)
unicode-display_width (2.4.2)
Expand All @@ -87,11 +86,12 @@ PLATFORMS
x86_64-linux

DEPENDENCIES
faraday-follow_redirects (~> 0.3)
minitest (~> 5.18)
ontologies_api_client!
pry
rake
rubocop (~> 1.43)
test-unit

BUNDLED WITH
2.3.22
14 changes: 9 additions & 5 deletions config/config.test.rb
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
# frozen_string_literal: true

# config.rb is required for testing
# unit test makes calls to bioportal api so it needs a valid API key which can
# be set via ENV variable UT_APIKEY
abort('UT_APIKEY env variable is not set. Canceling tests') unless ENV.include?('UT_APIKEY')
abort('UT_APIKEY env variable is set to an empty value. Canceling tests') unless ENV['UT_APIKEY'].size > 5

LinkedData::Client.config do |config|
config.rest_url = 'https://data.bioontology.org'
config.apikey = ENV['UT_APIKEY']
# config.apikey = 'xxxxx-xxxxx-xxxxxxxxxx'
config.links_attr = 'links'
config.cache = false
config.rest_url = 'https://data.bioontology.org'
config.apikey = ENV['UT_APIKEY']
# config.apikey = 'xxxxx-xxxxx-xxxxxxxxxx'
config.links_attr = 'links'
config.purl_host = 'purl.bioontology.org'
config.purl_prefix = 'https://purl.bioontology.org/ontology'
config.cache = false
end
1 change: 1 addition & 0 deletions lib/ontologies_api_client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
require_relative 'ontologies_api_client/collection'
require_relative 'ontologies_api_client/read_write'
require_relative 'ontologies_api_client/analytics'
require_relative 'ontologies_api_client/version'

# Models
curr_dir = File.expand_path("../ontologies_api_client", __FILE__)
Expand Down
29 changes: 17 additions & 12 deletions lib/ontologies_api_client/config.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
# frozen_string_literal: true

require 'ostruct'
require 'faraday'
require 'faraday/excon'
Expand All @@ -16,27 +18,30 @@ module Client

def config(&block)
return if @settings_run

@settings_run = true

yield @settings if block_given?

# Set defaults
@settings.rest_url ||= "http://stagedata.bioontology.org"
@settings.apikey ||= "4ea81d74-8960-4525-810b-fa1baab576ff"
@settings.links_attr ||= "links"
@settings.rest_url ||= 'http://stagedata.bioontology.org'
@settings.apikey ||= '4ea81d74-8960-4525-810b-fa1baab576ff'
@settings.links_attr ||= 'links'
@settings.cache ||= false
@settings.enable_long_request_log ||= false
@settings.purl_prefix ||= "http://purl.example.org"
@settings.purl_prefix ||= 'http://purl.example.org'
@settings.purl_host ||= 'purl.example.org'

# Remove trailing slash
@settings.rest_url = @settings.rest_url.chomp("/")
@settings.purl_prefix = @settings.purl_prefix.chomp("/")
@settings.rest_url = @settings.rest_url.chomp('/')
@settings.purl_prefix = @settings.purl_prefix.chomp('/')

@settings_run = true
end

def config_connection(options = {})
return if @settings_run_connection

store = options[:cache_store]
@settings.conn = Faraday.new(@settings.rest_url) do |faraday|
if @settings.enable_long_request_log
Expand All @@ -57,20 +62,20 @@ def config_connection(options = {})
begin
require_relative 'middleware/faraday-object-cache'
faraday.use :object_cache, store: store
puts "=> faraday caching enabled"
puts '=> faraday caching enabled'
puts "=> faraday cache store: #{store.class}"
rescue LoadError
puts "=> WARNING: faraday http cache gem is not available, caching disabled"
puts '=> WARNING: faraday http cache gem is not available, caching disabled'
end
end

faraday.request :multipart
faraday.request :url_encoded
faraday.adapter :excon
faraday.headers = {
"Accept" => "application/json",
"Authorization" => "apikey token=#{@settings.apikey}",
"User-Agent" => "NCBO API Ruby Client v0.1.0"
'Accept' => 'application/json',
'Authorization' => "apikey token=#{@settings.apikey}",
'User-Agent' => "NCBO API Ruby Client v#{LinkedData::Client::VERSION}"
}
end
@settings_run_connection = true
Expand All @@ -80,4 +85,4 @@ def connection_configured?
@settings_run_connection
end
end
end
end
2 changes: 1 addition & 1 deletion lib/ontologies_api_client/models/class.rb
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ def to_jsonld

def purl
return "" if self.links.nil?
return self.id if self.id.include?("purl.")
return self.id if self.id.include? LinkedData::Client.settings[:purl_host]

ont = self.explore.ontology
encoded_id = Addressable::URI.encode_component(self.id, Addressable::URI::CharacterClasses::UNRESERVED)
Expand Down
7 changes: 7 additions & 0 deletions lib/ontologies_api_client/version.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# frozen_string_literal: true

module LinkedData
module Client
VERSION = '2.2.4'
end
end
7 changes: 6 additions & 1 deletion ontologies_api_client.gemspec
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
# frozen_string_literal: true

require_relative 'lib/ontologies_api_client/version'

Gem::Specification.new do |gem|
gem.authors = ['Paul R Alexander']
gem.email = ['[email protected]']
Expand All @@ -14,7 +16,7 @@ Gem::Specification.new do |gem|
gem.test_files = gem.files.grep(%r{^(test|spec|features)/})
gem.name = 'ontologies_api_client'
gem.require_paths = ['lib']
gem.version = '2.2.2'
gem.version = LinkedData::Client::VERSION

gem.add_dependency('activesupport', '6.1.7.3')
gem.add_dependency('addressable', '~> 2.8')
Expand All @@ -26,4 +28,7 @@ Gem::Specification.new do |gem|
gem.add_dependency('multi_json')
gem.add_dependency('oj')
gem.add_dependency('spawnling', '2.1.5')

gem.add_development_dependency('faraday-follow_redirects', '~> 0.3')
gem.add_development_dependency('minitest', '~> 5.18')
end
59 changes: 58 additions & 1 deletion test/models/test_class.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
# frozen_string_literal: true

require 'faraday/follow_redirects'
require_relative '../test_case'

class ClassTest < LinkedData::Client::TestCase
Expand All @@ -11,6 +14,60 @@ def test_find
assert_equal 'http://www.w3.org/2002/07/owl#Class', cls.type
assert_equal 'Activity', cls.prefLabel
assert_equal ontology, cls.links['ontology']
assert_true cls.hasChildren
assert cls.hasChildren
end

# Test PURL generation for a class in an OWL format ontology
def test_purl_owl
cls = LinkedData::Client::Models::Class.find(
'http://bioontology.org/ontologies/Activity.owl#Activity',
'https://data.bioontology.org/ontologies/BRO'
)
refute_nil cls

res = fetch_response(cls.purl)
assert_equal 200, res.status
assert_equal 'https://bioportal.bioontology.org/ontologies/BRO'\
'?p=classes&conceptid=http%3A%2F%2Fbioontology.org%2Fontologies%2FActivity.owl%23Activity',
res.env[:url].to_s
end

# Test PURL generation for a class in a UMLS format ontology
def test_purl_umls
cls = LinkedData::Client::Models::Class.find(
'http://purl.bioontology.org/ontology/SNOMEDCT/64572001',
'https://bioportal.bioontology.org/ontologies/SNOMEDCT'
)
refute_nil cls

res = fetch_response(cls.purl)
assert_equal 200, res.status
assert_equal 'https://bioportal.bioontology.org/ontologies/SNOMEDCT?p=classes&conceptid=64572001',
res.env[:url].to_s
end

# Test PURL generation for a class in an OBO format ontology
def test_purl_obo
cls = LinkedData::Client::Models::Class.find(
'http://purl.obolibrary.org/obo/DOID_4',
'https://bioportal.bioontology.org/ontologies/DOID'
)
refute_nil cls

res = fetch_response(cls.purl)
assert_equal 200, res.status
assert_equal 'https://bioportal.bioontology.org/ontologies/DOID'\
'?p=classes&conceptid=http%3A%2F%2Fpurl.obolibrary.org%2Fobo%2FDOID_4',
res.env[:url].to_s
end

private

def fetch_response(url)
conn = Faraday.new do |f|
f.response :follow_redirects
f.adapter Faraday.default_adapter
end
conn.get(url)
end
end
26 changes: 14 additions & 12 deletions test/models/test_collection.rb
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
require_relative '../test_case'
# frozen_string_literal: true

require 'pry'
require_relative '../test_case'

class TestOntology < LinkedData::Client::Base
include LinkedData::Client::Collection
include LinkedData::Client::ReadWrite

@media_type = "http://data.bioontology.org/metadata/Ontology"
@include_attrs = "all"
@media_type = 'http://data.bioontology.org/metadata/Ontology'
@include_attrs = 'all'
end

class CollectionTest < LinkedData::Client::TestCase
Expand All @@ -16,30 +18,30 @@ def test_all
end

def test_class_for_type
media_type = "http://data.bioontology.org/metadata/Category"
media_type = 'http://data.bioontology.org/metadata/Category'
type_cls = LinkedData::Client::Base.class_for_type(media_type)
assert type_cls == LinkedData::Client::Models::Category
assert_equal LinkedData::Client::Models::Category, type_cls
end

def test_find_by
bro = TestOntology.find_by_acronym("BRO")
bro = TestOntology.find_by_acronym('BRO')
assert bro.length >= 1
assert bro.any? {|o| o.acronym.eql?("BRO")}
assert(bro.any? { |o| o.acronym.eql?('BRO') })

onts = TestOntology.find_by_hasDomain_and_doNotUpdate("https://data.bioontology.org/categories/Health", true)
onts = TestOntology.find_by_hasDomain_and_doNotUpdate('https://data.bioontology.org/categories/Health', true)
assert onts.length >= 1

onts = TestOntology.find_by_hasDomain_and_hasDomain("https://data.bioontology.org/categories/Phenotype", "https://data.bioontology.org/categories/Human")
onts = TestOntology.find_by_hasDomain_and_hasDomain('https://data.bioontology.org/categories/Phenotype', 'https://data.bioontology.org/categories/Human')
assert onts.length >= 1
end

def test_where
onts = TestOntology.where {|o| o.name.downcase.start_with?("c")}
onts = TestOntology.where { |o| o.name.downcase.start_with?('c') }
assert onts.length >= 1
end

def test_find
ont = TestOntology.find("https://data.bioontology.org/ontologies/SNOMEDCT")
assert !ont.nil?
ont = TestOntology.find('https://data.bioontology.org/ontologies/SNOMEDCT')
refute_nil ont
end
end
6 changes: 4 additions & 2 deletions test/test_case.rb
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
require 'test-unit'
# frozen_string_literal: true

require 'minitest/autorun'
require_relative '../lib/ontologies_api_client'
require_relative '../config/config'

module LinkedData
module Client
class TestCase < Test::Unit::TestCase
class TestCase < Minitest::Test
end
end
end

0 comments on commit 0feaef1

Please sign in to comment.