-
Notifications
You must be signed in to change notification settings - Fork 900
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix currency list on new money gem #19567
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,31 +1,30 @@ | ||
describe ChargebackRateDetailCurrency do | ||
describe '.seed' do | ||
before do | ||
it "returns supported currencies" do | ||
ChargebackRateDetailCurrency.seed | ||
end | ||
|
||
let(:expected_currencies) do | ||
%w(AED AFN ALL AMD ANG AOA ARS AUD AWG AZN BAM BBD BDT BGN BHD BIF BMD BND BOB BRL BSD BTN BWP BYN BYR BZD CAD CDF CHF CLF CLP CNY COP CRC CUC CUP CVE CZK DJF DKK DOP DZD EGP ERN ETB EUR FJD FKP GBP GEL GHS GIP GMD GNF GTQ GYD HKD HNL HRK HTG HUF IDR ILS INR IQD IRR ISK JMD JOD JPY KES KGS KHR KMF KPW KRW KWD KYD KZT LAK LBP LKR LRD LSL LYD MAD MDL MGA MKD MMK MNT MOP MRO MUR MVR MWK MXN MYR MZN NAD NGN NIO NOK NPR NZD OMR PAB PEN PGK PHP PKR PLN PYG QAR RON RSD RUB RWF SAR SBD SCR SDG SEK SGD SHP SKK SLL SOS SRD SSP STD SVC SYP SZL THB TJS TMT TND TOP TRY TTD TWD TZS UAH UGX USD UYU VES VND VUV WST XAF XAG XAU XCD XDR XOF XPD XPF XPT YER ZAR ZMK ZMW) | ||
end | ||
expected_currencies = %w[AED AFN ALL AMD ANG AOA ARS AUD AWG AZN BAM BBD BDT BGN BHD BIF BMD BND BOB BRL BSD BTN BWP BYN BYR BZD CAD CDF CHF CLF CLP CNY COP CRC CUC CUP CVE CZK DJF DKK DOP DZD EGP ERN ETB EUR FJD FKP GBP GEL GHS GIP GMD GNF GTQ GYD HKD HNL HRK HTG HUF IDR ILS INR IQD IRR ISK JMD JOD JPY KES KGS KHR KMF KPW KRW KWD KYD KZT LAK LBP LKR LRD LSL LYD MAD MDL MGA MKD MMK MNT MOP MRU MUR MVR MWK MXN MYR MZN NAD NGN NIO NOK NPR NZD OMR PAB PEN PGK PHP PKR PLN PYG QAR RON RSD RUB RWF SAR SBD SCR SDG SEK SGD SHP SKK SLL SOS SRD SSP STD SVC SYP SZL THB TJS TMT TND TOP TRY TTD TWD TZS UAH UGX USD UYU UZS VES VND VUV WST XAF XAG XAU XCD XDR XOF XPD XPF XPT YER ZAR ZMK ZMW] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hard to tell in the PR diff (easier to see in the first commit's diff), but there are 2 changes here...
The latter is interesting because it seems seed doesn't delete old currencies, nor does it have a way to "update" old currencies where the code has changed. I'm not sure if that's a good thing or a bad thing. @lpichler Thoughts? Should we have a data migration moving MRO to MRU, and then delete old currencies? Or should we just leave it the way it is, which is technically backwards compatibile? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm fine with keeping this for now but this test feels brittle. We'll have to change this whenever money adds/removes/renames currencies, right? Maybe we should be looking for specific subset of newer currencies we want to test against? I do like the dropping of the currency count test though. 👍 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, the test is brittle, and a subset is the only thing I can think of as well. I think that's better as a follow up PR though. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yeah, let's do the followup after this PR is merged. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
@Fryguy Change MRO to MRU is basically: removing one old currency and adding new. So if anybody used MRO - I prefer to keep MRO as he selected it. If anybody created report/chargeback rate/services/,,, with MRO and we will change it to MRU without conversions of prices and are changing meaning of it - so I suggest don't change it. If there will be change in symbol because of typo,.. we can create migration symbol is unique identification for seeding.
this is a reason why there is the test - to be informed about external changes. anyway do you think that we can copy their json with currencies to our project ? (I don't know how to judge this) because we need (or we will soon) money gem just because of this file(list of currencies). thanks! |
||
|
||
it "returns supported currencies" do | ||
expect(ChargebackRateDetailCurrency.count).to eq(164) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Dropped this count test since it's really just a duplicate of checking all of the currencies |
||
expect(ChargebackRateDetailCurrency.all.map(&:code)).to match_array(expected_currencies) | ||
end | ||
end | ||
|
||
it "has a valid factory" do | ||
expect(FactoryBot.create(:chargeback_rate_detail_currency)).to be_valid | ||
end | ||
|
||
it "is invalid without a code" do | ||
expect(FactoryBot.build(:chargeback_rate_detail_currency, :code => nil)).not_to be_valid | ||
end | ||
|
||
it "is invalid without a name" do | ||
expect(FactoryBot.build(:chargeback_rate_detail_currency, :name => nil)).not_to be_valid | ||
end | ||
|
||
it "is invalid without a full_name" do | ||
expect(FactoryBot.build(:chargeback_rate_detail_currency, :full_name => nil)).not_to be_valid | ||
end | ||
|
||
it "is invalid without a symbol" do | ||
expect(FactoryBot.build(:chargeback_rate_detail_currency, :symbol => nil)).not_to be_valid | ||
end | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Fryguy I think the
Money
class was coming from themoney-rails
gem here - https://github.com/ManageIQ/manageiq-consumption/blob/c7198b50c03944497b00fd28284caf723a88ff1b/manageiq-consumption.gemspec#L20, not themoney
gem. I'm not sure that it matters since we only use the gem for its list of currencies, but I thought I should mention it. I had added themoney-rails
gem to the PR that decouples us frommanageiq-consumption
and noticed this what I tried to rebase it with this change.