Commit b1bcd8c7 authored by Aishwarya Subramanian's avatar Aishwarya Subramanian Committed by James Lopez

Added controller for country list

Added specs for countries controller
Added missing frozen string literal
Reworded comments for gemfile
Addressing Rubocop public_send offence
parent d60cc09b
...@@ -465,3 +465,6 @@ gem 'grape_logging', '~> 1.7' ...@@ -465,3 +465,6 @@ gem 'grape_logging', '~> 1.7'
# DNS Lookup # DNS Lookup
gem 'net-dns', '~> 0.9.0' gem 'net-dns', '~> 0.9.0'
# Countries list
gem 'countries', '~> 3.0'
...@@ -167,6 +167,10 @@ GEM ...@@ -167,6 +167,10 @@ GEM
contracts (0.11.0) contracts (0.11.0)
cork (0.3.0) cork (0.3.0)
colored2 (~> 3.1) colored2 (~> 3.1)
countries (3.0.0)
i18n_data (~> 0.8.0)
sixarm_ruby_unaccent (~> 1.1)
unicode_utils (~> 1.4)
crack (0.4.3) crack (0.4.3)
safe_yaml (~> 1.0.0) safe_yaml (~> 1.0.0)
crass (1.0.4) crass (1.0.4)
...@@ -485,6 +489,7 @@ GEM ...@@ -485,6 +489,7 @@ GEM
httpclient (2.8.3) httpclient (2.8.3)
i18n (1.6.0) i18n (1.6.0)
concurrent-ruby (~> 1.0) concurrent-ruby (~> 1.0)
i18n_data (0.8.0)
icalendar (2.4.1) icalendar (2.4.1)
ice_nine (0.11.2) ice_nine (0.11.2)
influxdb (0.2.3) influxdb (0.2.3)
...@@ -954,6 +959,7 @@ GEM ...@@ -954,6 +959,7 @@ GEM
json (>= 1.8, < 3) json (>= 1.8, < 3)
simplecov-html (~> 0.10.0) simplecov-html (~> 0.10.0)
simplecov-html (0.10.2) simplecov-html (0.10.2)
sixarm_ruby_unaccent (1.2.0)
slack-notifier (1.5.1) slack-notifier (1.5.1)
snowplow-tracker (0.6.1) snowplow-tracker (0.6.1)
contracts (~> 0.7, <= 0.11) contracts (~> 0.7, <= 0.11)
...@@ -1018,6 +1024,7 @@ GEM ...@@ -1018,6 +1024,7 @@ GEM
unf_ext unf_ext
unf_ext (0.0.7.5) unf_ext (0.0.7.5)
unicode-display_width (1.6.0) unicode-display_width (1.6.0)
unicode_utils (1.4.0)
unicorn (5.4.1) unicorn (5.4.1)
kgio (~> 2.6) kgio (~> 2.6)
raindrops (~> 0.7) raindrops (~> 0.7)
...@@ -1117,6 +1124,7 @@ DEPENDENCIES ...@@ -1117,6 +1124,7 @@ DEPENDENCIES
commonmarker (~> 0.17) commonmarker (~> 0.17)
concurrent-ruby (~> 1.1) concurrent-ruby (~> 1.1)
connection_pool (~> 2.0) connection_pool (~> 2.0)
countries (~> 3.0)
creole (~> 0.5.0) creole (~> 0.5.0)
danger (~> 6.0) danger (~> 6.0)
database_cleaner (~> 1.7.0) database_cleaner (~> 1.7.0)
......
...@@ -613,3 +613,10 @@ ...@@ -613,3 +613,10 @@
:why: https://bitbucket.org/atlassian/atlassian-jwt-ruby/src/master/LICENSE.txt :why: https://bitbucket.org/atlassian/atlassian-jwt-ruby/src/master/LICENSE.txt
:versions: [] :versions: []
:when: 2019-08-30 05:45:35.317663000 Z :when: 2019-08-30 05:45:35.317663000 Z
- - :license
- unicode_utils
- MIT
- :who: Aishwarya Subramanain
:why: https://github.com/hexorx/countries/blob/master/LICENSE
:versions: []
:when: 2019-09-11 13:08:28.431132000 Z
# frozen_string_literal: true
ISO3166.configure do |config|
config.locales = [:en]
end
# GitLab permits users to sign up in Ukraine except the Crimean Region: https://about.gitlab.com/handbook/people-operations/code-of-conduct/#trade-compliance-exportimport-control
# This overrides the display name for Ukraine to Ukraine (except Crimean Region)
# To be removed after https://gitlab.com/gitlab-org/gitlab-ee/issues/14784 is implemented
# Data fetched is based on https://github.com/hexorx/countries/blob/master/lib/countries/data/countries/UA.yaml
ISO3166::Data.register(
continent: "Europe",
address_format: "|-
{{recipient}}
{{street}}
{{city}} {{region_short}}
{{postalcode}}
{{country}}",
alpha2: "UA",
alpha3: "UKR",
country_code: '380',
international_prefix: '810',
ioc: "UKR",
gec: "UP",
name: "Ukraine (except Crimean Region)",
national_destination_code_lengths: [2],
national_number_lengths: [8, 9],
national_prefix: '8',
number: '804',
region: "Europe",
subregion: "Eastern Europe",
world_region: "EMEA",
un_locode: "UA",
nationality: "Ukrainian",
vat_rates: {
standard: 20
},
reduced: [7],
super_reduced: {
parking: { postal_code: true }
},
unofficial_names: %w(Ukraine Ucrania ウクライナ Oekraïne Украина Україна Украіна),
languages_official: ["uk"],
languages_spoken: ["uk"],
geo: {
latitude: 48.379433,
latitude_dec: '48.92656326293945',
longitude: 31.16558,
longitude_dec: '31.47578239440918',
max_latitude: 52.37958099999999,
max_longitude: 40.2285809,
min_latitude: 44.2924,
min_longitude: 22.137159,
bounds: {
northeast: { lat: 52.37958099999999, lng: 40.2285809 },
southwest: { lat: 44.2924, lng: 22.137159 }
}
},
currency_code: "UAH",
start_of_week: "monday"
)
...@@ -113,6 +113,7 @@ Rails.application.routes.draw do ...@@ -113,6 +113,7 @@ Rails.application.routes.draw do
draw :username draw :username
draw :trial draw :trial
draw :trial_registration draw :trial_registration
draw :country
end end
Gitlab.ee do Gitlab.ee do
......
# frozen_string_literal: true
class CountriesController < ActionController::Metal
include AbstractController::Rendering
include ActionController::Renderers::All
def index
countries = World.countries_for_select
render json: countries, status: (countries ? :ok : :not_found)
end
end
# frozen_string_literal: true
resources :countries, only: [:index]
# frozen_string_literal: true
module World
include ::Gitlab::Utils::StrongMemoize
extend self
DENYLIST = ['Iran (Islamic Republic of)', 'Sudan', 'Syrian Arab Republic', 'Korea', 'Democratic People\'s Republic of', 'Cuba'].freeze
def countries_for_select
strong_memoize(:countries_for_select) { all_countries.sort_by(&:name).map { |c| [c.name, c.alpha2] } }
end
def all_countries
strong_memoize(:all_countries) { ISO3166::Country.all.reject {|item| DENYLIST.include?(item.name) } }
end
end
# frozen_string_literal: true
require 'spec_helper'
describe CountriesController do
describe 'GET #index' do
it 'returns list of countries as json' do
get :index
expected_json = World.countries_for_select.to_json
expect(response.status).to eq(200)
expect(response.body).to eq(expected_json)
end
it 'does not include list of denied countries' do
get :index
# response is returned as [["Afghanistan", "AF"], ["Albania", "AL"], ..]
resultant_countries = JSON.parse(response.body).map {|row| row[0]}
expect(resultant_countries).not_to include(World::DENYLIST)
end
end
end
# frozen_string_literal: true
require 'spec_helper'
describe World do
describe '.all_countries' do
it 'does not return countries that are in the denied list' do
result = described_class.all_countries
expect(result.map(&:name)).not_to include(World::DENYLIST)
end
end
describe '.countries_for_select' do
it 'returns list of country name and iso_code in alphabetical format' do
result = described_class.countries_for_select
expect(result.first).to eq(%w[Afghanistan AF])
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment