348 lines
10 KiB
Ruby
348 lines
10 KiB
Ruby
# Copyright 2015 Google Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
require 'spec_helper'
|
|
require 'google/apis/generator'
|
|
require 'tmpdir'
|
|
require 'fileutils'
|
|
|
|
# TODO - Naked arrays in method requests/responses
|
|
|
|
RSpec.describe Google::Apis::Generator do
|
|
include TestHelpers
|
|
|
|
context 'with test API' do
|
|
before(:context) do
|
|
generator = Google::Apis::Generator.new(api_names: File.join(FIXTURES_DIR, 'files', 'api_names.yaml'))
|
|
discovery = File.read(File.join(FIXTURES_DIR, 'files', 'test_api.json'))
|
|
generated_files = generator.render(discovery)
|
|
# puts generator.dump_api_names
|
|
tempdir = Dir.mktmpdir
|
|
generated_files.each do |key, content|
|
|
# puts content
|
|
path = File.join(tempdir, key)
|
|
FileUtils.mkdir_p(File.dirname(path))
|
|
File.open(path, 'w') do |f|
|
|
f.write(content)
|
|
end
|
|
end
|
|
$LOAD_PATH.unshift(tempdir)
|
|
require 'google/apis/test_v1'
|
|
end
|
|
|
|
let(:service) { Google::Apis::TestV1::TestService.new }
|
|
|
|
context 'with the generated service' do
|
|
it 'should set the base URL' do
|
|
expect(service.root_url.to_s).to eql('https://www.googleapis.com/')
|
|
end
|
|
|
|
it 'should set the batch path' do
|
|
expect(service.batch_path).to eql('batch/test/v1')
|
|
end
|
|
|
|
it 'should define global methods from discovery' do
|
|
expect(service.method(:query)).to_not be_nil
|
|
end
|
|
|
|
it 'should define parameters on methods' do
|
|
parameters = service.method(:query).parameters.map { |(_k, v)| v }
|
|
expect(parameters).to include(:s, :i, :n, :b, :a, :e, :er, :sr)
|
|
end
|
|
|
|
it 'should modify parameter names that are ruby keywords' do
|
|
parameters = service.method(:query).parameters.map { |(_k, v)| v }
|
|
expect(parameters).to include(:do_)
|
|
end
|
|
|
|
it 'should define global parameters on methods' do
|
|
parameters = service.method(:query).parameters.map { |(_k, v)| v }
|
|
expect(parameters).to include(:fields, :quota_user, :user_ip)
|
|
end
|
|
|
|
it 'should include standard options & block' do
|
|
parameters = service.method(:query).parameters.map { |(_k, v)| v }
|
|
expect(parameters).to include(:options, :block)
|
|
end
|
|
|
|
it 'should define AUTH_TEST scope' do
|
|
expect(Google::Apis::TestV1::AUTH_TEST).to eql ('https://www.googleapis.com/auth/test')
|
|
end
|
|
|
|
it 'should define AUTH_TEST_READONLY scope' do
|
|
expect(Google::Apis::TestV1::AUTH_TEST_READONLY).to eql ('https://www.googleapis.com/auth/test.readonly')
|
|
end
|
|
|
|
context 'when simplifying class names' do
|
|
it 'should simplify the TestAnotherThing name' do
|
|
expect { Google::Apis::TestV1::AnotherThing.new }.not_to raise_error
|
|
end
|
|
|
|
it 'should not simplify the TestThing name' do
|
|
expect { Google::Apis::TestV1::TestThing.new }.not_to raise_error
|
|
end
|
|
end
|
|
|
|
|
|
context 'with the Thing resource' do
|
|
it 'should define the create method`' do
|
|
expect(service.method(:create_thing)).to_not be_nil
|
|
end
|
|
|
|
it 'should define the list method`' do
|
|
expect(service.method(:list_things)).to_not be_nil
|
|
end
|
|
|
|
it 'should define the get method`' do
|
|
expect(service.method(:get_thing)).to_not be_nil
|
|
end
|
|
|
|
it 'should include the download_dest parameter for get_thing' do
|
|
parameters = service.method(:get_thing).parameters.map { |(_k, v)| v }
|
|
expect(parameters).to include(:download_dest)
|
|
end
|
|
|
|
it 'should define the update method`' do
|
|
expect(service.method(:update_thing)).to_not be_nil
|
|
end
|
|
|
|
it 'should include the upload_source parameter for update_thing' do
|
|
parameters = service.method(:update_thing).parameters.map { |(_k, v)| v }
|
|
expect(parameters).to include(:upload_source)
|
|
end
|
|
|
|
it 'should define subresource methods' do
|
|
expect(service.method(:list_thing_subthings)).to_not be_nil
|
|
end
|
|
|
|
context 'With the from_json method' do
|
|
let(:json) do
|
|
<<EOF
|
|
{
|
|
"name" : "A thing",
|
|
"properties": {
|
|
"prop_a" : "value_a"
|
|
},
|
|
"photo": {
|
|
"filename": "image.jpg"
|
|
},
|
|
"hat": {
|
|
"type": "topHat",
|
|
"height": 100
|
|
}
|
|
}
|
|
EOF
|
|
end
|
|
|
|
let(:thing) { Google::Apis::TestV1::Thing.from_json(json) }
|
|
|
|
it 'should return a thing' do
|
|
expect(thing).to be_instance_of(Google::Apis::TestV1::Thing)
|
|
end
|
|
|
|
it 'should parse properties' do
|
|
expect(thing.name).to eq 'A thing'
|
|
end
|
|
|
|
it 'should parse subtypes' do
|
|
expect(thing.photo.filename).to eq "image.jpg"
|
|
end
|
|
end
|
|
|
|
context 'With the to_json method' do
|
|
let(:thing) do
|
|
Google::Apis::TestV1::Thing.new(
|
|
name: "A thing",
|
|
properties: {
|
|
prop_a: "value_a"
|
|
},
|
|
photo: {
|
|
filename: "image.jpg"
|
|
},
|
|
hat: {
|
|
type: "topHat",
|
|
height: 100
|
|
}
|
|
)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with the get_thing method' do
|
|
before(:example) do
|
|
json = <<EOF
|
|
{
|
|
"id" : "123",
|
|
"name" : "A thing",
|
|
"enabled": true,
|
|
"properties": {
|
|
"prop_a" : "value_a",
|
|
"prop_b" : "value_b"
|
|
},
|
|
"photo": {
|
|
"filename": "image.jpg"
|
|
},
|
|
"hat": {
|
|
"type": "baseballHat",
|
|
"color": "red"
|
|
}
|
|
}
|
|
EOF
|
|
stub_request(:get, 'https://www.googleapis.com/test/v1/things/123')
|
|
.to_return(headers: { 'Content-Type' => 'application/json' }, body: json)
|
|
end
|
|
|
|
let(:thing) { service.get_thing('123') }
|
|
|
|
it 'should return a Thing' do
|
|
expect(thing).to be_instance_of(Google::Apis::TestV1::Thing)
|
|
end
|
|
|
|
it 'should set attributes' do
|
|
expect(thing.id).to eql '123'
|
|
end
|
|
|
|
it 'should alias boolean methods on Thing' do
|
|
expect(thing.enabled?).to be true
|
|
end
|
|
|
|
it 'should return a Hash for properties' do
|
|
expect(thing.properties).to be_instance_of(Hash)
|
|
end
|
|
|
|
it 'should set hash elements' do
|
|
expect(thing.properties).to include('prop_a' => 'value_a')
|
|
end
|
|
|
|
it 'should return the correct variant type for hat' do
|
|
expect(thing.hat).to be_instance_of(Google::Apis::TestV1::BaseballHat)
|
|
end
|
|
|
|
it 'should return the correct variant properties for hat' do
|
|
expect(thing.hat.color).to eql 'red'
|
|
end
|
|
|
|
it 'should return a photo' do
|
|
expect(thing.photo).to be_instance_of(Google::Apis::TestV1::Thing::Photo)
|
|
end
|
|
|
|
it 'should return photo properties' do
|
|
expect(thing.photo.filename).to eql 'image.jpg'
|
|
end
|
|
end
|
|
|
|
context 'with the create_thing method' do
|
|
before(:example) do
|
|
json = <<EOF
|
|
{
|
|
"id" : "123",
|
|
"name" : "A thing",
|
|
"properties": {
|
|
"prop_a" : "value_a"
|
|
},
|
|
"photo": {
|
|
"filename": "image.jpg"
|
|
},
|
|
"hat": {
|
|
"type": "topHat",
|
|
"height": 100
|
|
}
|
|
}
|
|
EOF
|
|
stub_request(:post, 'https://www.googleapis.com/test/v1/things')
|
|
.to_return(headers: { 'Content-Type' => 'application/json' }, body: json)
|
|
end
|
|
|
|
let(:thing) do
|
|
thing = Google::Apis::TestV1::Thing.new(name: 'A thing', properties: { 'prop_a' => 'value_a' })
|
|
thing.photo = Google::Apis::TestV1::Thing::Photo.new(filename: 'image.jpg')
|
|
thing.hat = Google::Apis::TestV1::TopHat.new(type: 'topHat', height: 100)
|
|
service.create_thing(thing)
|
|
end
|
|
|
|
it 'should serialize the thing' do
|
|
expected_body = <<EOF
|
|
{
|
|
"name" : "A thing",
|
|
"properties": {
|
|
"prop_a" : "value_a"
|
|
},
|
|
"photo": {
|
|
"filename": "image.jpg"
|
|
},
|
|
"hat": {
|
|
"type": "topHat",
|
|
"height": 100
|
|
}
|
|
}
|
|
EOF
|
|
expect(thing).to be_instance_of(Google::Apis::TestV1::Thing)
|
|
expect(a_request(:post, 'https://www.googleapis.com/test/v1/things')
|
|
.with { |req| expect(req.body).to be_json_eql(expected_body) }).to have_been_made
|
|
end
|
|
|
|
it 'should an updated id' do
|
|
expect(thing.id).to eql '123'
|
|
end
|
|
end
|
|
|
|
context 'with the query method' do
|
|
before(:example) do
|
|
body = %({"rows": [{"value": "hello"}, {"value": "world"}]})
|
|
stub_request(:get, 'https://www.googleapis.com/test/v1/query')
|
|
.to_return(headers: { 'Content-Type' => 'application/json' }, body: body)
|
|
end
|
|
|
|
it 'should return query results' do
|
|
results = service.query
|
|
expect(results).to be_instance_of(Google::Apis::TestV1::QueryResults)
|
|
end
|
|
|
|
it 'should return an array for items' do
|
|
results = service.query
|
|
expect(results.rows).to be_instance_of(Array)
|
|
end
|
|
|
|
it 'should return items of type Row' do
|
|
results = service.query
|
|
expect(results.rows.first).to be_instance_of(Google::Apis::TestV1::Row)
|
|
end
|
|
|
|
it 'should return values for rows' do
|
|
results = service.query
|
|
expect(results.rows[1].value).to eql('world')
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with minimal API description' do
|
|
before do
|
|
generated_files = Google::Apis::Generator.new.render(
|
|
'{ "name": "minimal_api", "id": "minimal_api", "version": "v1" }'
|
|
)
|
|
|
|
namespace.send(:binding).eval(
|
|
generated_files.fetch('google/apis/minimal_api_v1/service.rb')
|
|
)
|
|
end
|
|
|
|
let(:namespace) { Module.new }
|
|
|
|
it 'should define service class' do
|
|
expect(namespace).to be_const_defined('Google::Apis::MinimalApiV1::MinimalApiService')
|
|
end
|
|
end
|
|
end
|