fortnox-api 0.9.2 → 1.0.0.rc2
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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +120 -95
- data/{LICENSE.txt → LICENSE.md} +0 -0
- data/README.md +245 -248
- data/bin/fortnox-setup +211 -0
- data/bin/fortnox-update-env +38 -0
- data/fortnox.gemspec +29 -0
- data/lib/fortnox/auth/thread_local.rb +28 -0
- data/lib/fortnox/collection.rb +23 -0
- data/lib/fortnox/mappers/country_code.rb +34 -0
- data/lib/fortnox/mappers/date.rb +21 -0
- data/lib/fortnox/mappers/document_row.rb +12 -0
- data/lib/fortnox/mappers/edi_information.rb +15 -0
- data/lib/fortnox/mappers/email_information.rb +11 -0
- data/lib/fortnox/mappers/invoice_row.rb +14 -0
- data/lib/fortnox/mappers/label_references.rb +24 -0
- data/lib/fortnox/mappers/order_row.rb +9 -0
- data/lib/fortnox/mappers/struct.rb +71 -0
- data/lib/fortnox/mappers/struct_array.rb +31 -0
- data/lib/fortnox/resource.rb +131 -0
- data/lib/fortnox/resources/article.rb +160 -0
- data/lib/fortnox/resources/customer.rb +209 -0
- data/lib/fortnox/resources/document.rb +202 -0
- data/lib/fortnox/resources/invoice.rb +92 -0
- data/lib/fortnox/resources/label.rb +15 -0
- data/lib/fortnox/resources/order.rb +38 -0
- data/lib/fortnox/resources/project.rb +41 -0
- data/lib/fortnox/resources/terms_of_payment.rb +23 -0
- data/lib/fortnox/resources/unit.rb +26 -0
- data/lib/fortnox/struct.rb +24 -0
- data/lib/fortnox/structs/default_delivery_types.rb +16 -0
- data/lib/fortnox/structs/default_templates.rb +19 -0
- data/lib/fortnox/structs/document_row.rb +62 -0
- data/lib/fortnox/structs/edi_information.rb +25 -0
- data/lib/fortnox/structs/email_information.rb +22 -0
- data/lib/fortnox/structs/invoice_row.rb +13 -0
- data/lib/fortnox/structs/order_row.rb +10 -0
- data/lib/fortnox/types.rb +129 -0
- data/lib/fortnox/{api/version.rb → version.rb} +1 -3
- data/lib/fortnox.rb +111 -0
- metadata +55 -580
- data/.codeclimate.yml +0 -20
- data/.env.template +0 -7
- data/.env.test +0 -11
- data/.gitignore +0 -20
- data/.rspec +0 -2
- data/.rubocop.yml +0 -41
- data/.tool-versions +0 -1
- data/.travis.yml +0 -32
- data/CLAUDE.md +0 -79
- data/CONTRIBUTE.md +0 -38
- data/DEVELOPER_README.md +0 -69
- data/Gemfile +0 -6
- data/Guardfile +0 -16
- data/Rakefile +0 -140
- data/bin/console +0 -22
- data/bin/fortnox +0 -285
- data/bin/get_tokens +0 -79
- data/bin/renew_tokens +0 -28
- data/docs/gotchas.md +0 -146
- data/fortnox-api.gemspec +0 -50
- data/lib/fortnox/api/mappers/article.rb +0 -23
- data/lib/fortnox/api/mappers/base/canonical_name_sym.rb +0 -21
- data/lib/fortnox/api/mappers/base/from_json.rb +0 -91
- data/lib/fortnox/api/mappers/base/to_json.rb +0 -66
- data/lib/fortnox/api/mappers/base.rb +0 -30
- data/lib/fortnox/api/mappers/customer.rb +0 -27
- data/lib/fortnox/api/mappers/default_delivery_types.rb +0 -15
- data/lib/fortnox/api/mappers/default_templates.rb +0 -16
- data/lib/fortnox/api/mappers/edi_information.rb +0 -23
- data/lib/fortnox/api/mappers/email_information.rb +0 -19
- data/lib/fortnox/api/mappers/invoice.rb +0 -29
- data/lib/fortnox/api/mappers/invoice_row.rb +0 -25
- data/lib/fortnox/api/mappers/order.rb +0 -26
- data/lib/fortnox/api/mappers/order_row.rb +0 -23
- data/lib/fortnox/api/mappers/project.rb +0 -17
- data/lib/fortnox/api/mappers/terms_of_payment.rb +0 -17
- data/lib/fortnox/api/mappers/unit.rb +0 -17
- data/lib/fortnox/api/mappers/value/array.rb +0 -18
- data/lib/fortnox/api/mappers/value/country_string.rb +0 -24
- data/lib/fortnox/api/mappers/value/date.rb +0 -11
- data/lib/fortnox/api/mappers/value/hash.rb +0 -16
- data/lib/fortnox/api/mappers/value/identity.rb +0 -18
- data/lib/fortnox/api/mappers.rb +0 -21
- data/lib/fortnox/api/models/article.rb +0 -134
- data/lib/fortnox/api/models/base.rb +0 -128
- data/lib/fortnox/api/models/customer.rb +0 -210
- data/lib/fortnox/api/models/document.rb +0 -189
- data/lib/fortnox/api/models/invoice.rb +0 -87
- data/lib/fortnox/api/models/label.rb +0 -19
- data/lib/fortnox/api/models/order.rb +0 -27
- data/lib/fortnox/api/models/project.rb +0 -42
- data/lib/fortnox/api/models/terms_of_payment.rb +0 -28
- data/lib/fortnox/api/models/unit.rb +0 -24
- data/lib/fortnox/api/models.rb +0 -9
- data/lib/fortnox/api/repositories/article.rb +0 -17
- data/lib/fortnox/api/repositories/authentication.rb +0 -61
- data/lib/fortnox/api/repositories/base/loaders.rb +0 -64
- data/lib/fortnox/api/repositories/base/savers.rb +0 -57
- data/lib/fortnox/api/repositories/base.rb +0 -93
- data/lib/fortnox/api/repositories/customer.rb +0 -17
- data/lib/fortnox/api/repositories/invoice.rb +0 -17
- data/lib/fortnox/api/repositories/order.rb +0 -17
- data/lib/fortnox/api/repositories/project.rb +0 -17
- data/lib/fortnox/api/repositories/terms_of_payment.rb +0 -17
- data/lib/fortnox/api/repositories/unit.rb +0 -17
- data/lib/fortnox/api/repositories.rb +0 -10
- data/lib/fortnox/api/request_handling.rb +0 -46
- data/lib/fortnox/api/types/default_delivery_types.rb +0 -20
- data/lib/fortnox/api/types/default_templates.rb +0 -23
- data/lib/fortnox/api/types/defaulted.rb +0 -11
- data/lib/fortnox/api/types/document_row.rb +0 -64
- data/lib/fortnox/api/types/edi_information.rb +0 -29
- data/lib/fortnox/api/types/email_information.rb +0 -26
- data/lib/fortnox/api/types/enums.rb +0 -116
- data/lib/fortnox/api/types/invoice_row.rb +0 -19
- data/lib/fortnox/api/types/model.rb +0 -37
- data/lib/fortnox/api/types/nullable.rb +0 -25
- data/lib/fortnox/api/types/order_row.rb +0 -16
- data/lib/fortnox/api/types/required.rb +0 -13
- data/lib/fortnox/api/types/shim/country_string.rb +0 -10
- data/lib/fortnox/api/types/sized.rb +0 -33
- data/lib/fortnox/api/types.rb +0 -144
- data/lib/fortnox/api.rb +0 -62
- data/spec/fortnox/api/mappers/article_spec.rb +0 -17
- data/spec/fortnox/api/mappers/base/canonical_name_sym_spec.rb +0 -36
- data/spec/fortnox/api/mappers/base/from_json_spec.rb +0 -70
- data/spec/fortnox/api/mappers/base/to_json_spec.rb +0 -68
- data/spec/fortnox/api/mappers/base_spec.rb +0 -154
- data/spec/fortnox/api/mappers/contexts/json_conversion.rb +0 -62
- data/spec/fortnox/api/mappers/customer_spec.rb +0 -27
- data/spec/fortnox/api/mappers/default_delivery_types_spec.rb +0 -14
- data/spec/fortnox/api/mappers/edi_information_spec.rb +0 -23
- data/spec/fortnox/api/mappers/email_information_spec.rb +0 -19
- data/spec/fortnox/api/mappers/examples/mapper.rb +0 -34
- data/spec/fortnox/api/mappers/invoice_row_spec.rb +0 -24
- data/spec/fortnox/api/mappers/invoice_spec.rb +0 -27
- data/spec/fortnox/api/mappers/order_row_spec.rb +0 -21
- data/spec/fortnox/api/mappers/order_spec.rb +0 -23
- data/spec/fortnox/api/mappers/project_spec.rb +0 -12
- data/spec/fortnox/api/mappers/terms_of_payment_spec.rb +0 -16
- data/spec/fortnox/api/mappers/unit_spec.rb +0 -56
- data/spec/fortnox/api/models/article_spec.rb +0 -9
- data/spec/fortnox/api/models/base_spec.rb +0 -117
- data/spec/fortnox/api/models/customer_spec.rb +0 -9
- data/spec/fortnox/api/models/examples/document_base.rb +0 -15
- data/spec/fortnox/api/models/examples/model.rb +0 -22
- data/spec/fortnox/api/models/invoice_spec.rb +0 -11
- data/spec/fortnox/api/models/order_spec.rb +0 -12
- data/spec/fortnox/api/models/project_spec.rb +0 -9
- data/spec/fortnox/api/models/terms_of_payment_spec.rb +0 -9
- data/spec/fortnox/api/models/unit_spec.rb +0 -33
- data/spec/fortnox/api/repositories/article_spec.rb +0 -80
- data/spec/fortnox/api/repositories/authentication_spec.rb +0 -103
- data/spec/fortnox/api/repositories/base_spec.rb +0 -168
- data/spec/fortnox/api/repositories/customer_spec.rb +0 -119
- data/spec/fortnox/api/repositories/examples/all.rb +0 -17
- data/spec/fortnox/api/repositories/examples/find.rb +0 -84
- data/spec/fortnox/api/repositories/examples/only.rb +0 -34
- data/spec/fortnox/api/repositories/examples/save.rb +0 -76
- data/spec/fortnox/api/repositories/examples/save_with_nested_model.rb +0 -28
- data/spec/fortnox/api/repositories/examples/save_with_specially_named_attribute.rb +0 -26
- data/spec/fortnox/api/repositories/examples/search.rb +0 -39
- data/spec/fortnox/api/repositories/invoice_spec.rb +0 -297
- data/spec/fortnox/api/repositories/order_spec.rb +0 -53
- data/spec/fortnox/api/repositories/project_spec.rb +0 -36
- data/spec/fortnox/api/repositories/terms_of_payment_spec.rb +0 -34
- data/spec/fortnox/api/repositories/unit_spec.rb +0 -39
- data/spec/fortnox/api/types/account_number_spec.rb +0 -35
- data/spec/fortnox/api/types/country_code_spec.rb +0 -42
- data/spec/fortnox/api/types/country_spec.rb +0 -67
- data/spec/fortnox/api/types/default_delivery_types_spec.rb +0 -12
- data/spec/fortnox/api/types/edi_information_spec.rb +0 -15
- data/spec/fortnox/api/types/email_information_spec.rb +0 -15
- data/spec/fortnox/api/types/email_spec.rb +0 -56
- data/spec/fortnox/api/types/enums_spec.rb +0 -17
- data/spec/fortnox/api/types/examples/document_row.rb +0 -25
- data/spec/fortnox/api/types/examples/enum.rb +0 -55
- data/spec/fortnox/api/types/examples/types.rb +0 -11
- data/spec/fortnox/api/types/housework_types_spec.rb +0 -149
- data/spec/fortnox/api/types/invoice_row_spec.rb +0 -11
- data/spec/fortnox/api/types/model_spec.rb +0 -69
- data/spec/fortnox/api/types/nullable_spec.rb +0 -79
- data/spec/fortnox/api/types/order_row_spec.rb +0 -15
- data/spec/fortnox/api/types/required_spec.rb +0 -36
- data/spec/fortnox/api/types/sales_account_spec.rb +0 -57
- data/spec/fortnox/api/types/sized_spec.rb +0 -76
- data/spec/fortnox/api_spec.rb +0 -66
- data/spec/spec_helper.rb +0 -35
- data/spec/support/helpers/configuration_helper.rb +0 -39
- data/spec/support/helpers/repository_helper.rb +0 -10
- data/spec/support/helpers.rb +0 -3
- data/spec/support/matchers/type/attribute_matcher.rb +0 -40
- data/spec/support/matchers/type/enum_matcher.rb +0 -23
- data/spec/support/matchers/type/have_account_number_matcher.rb +0 -23
- data/spec/support/matchers/type/have_currency_matcher.rb +0 -9
- data/spec/support/matchers/type/have_customer_type_matcher.rb +0 -15
- data/spec/support/matchers/type/have_default_delivery_type_matcher.rb +0 -9
- data/spec/support/matchers/type/have_discount_type_matcher.rb +0 -9
- data/spec/support/matchers/type/have_email_matcher.rb +0 -24
- data/spec/support/matchers/type/have_housework_type_matcher.rb +0 -9
- data/spec/support/matchers/type/have_nullable_date_matcher.rb +0 -60
- data/spec/support/matchers/type/have_nullable_matcher.rb +0 -54
- data/spec/support/matchers/type/have_nullable_string_matcher.rb +0 -47
- data/spec/support/matchers/type/have_sized_float_matcher.rb +0 -10
- data/spec/support/matchers/type/have_sized_integer_matcher.rb +0 -10
- data/spec/support/matchers/type/have_sized_string_matcher.rb +0 -36
- data/spec/support/matchers/type/have_vat_type_matcher.rb +0 -9
- data/spec/support/matchers/type/numeric_matcher.rb +0 -52
- data/spec/support/matchers/type/require_attribute_matcher.rb +0 -68
- data/spec/support/matchers/type/type_matcher.rb +0 -40
- data/spec/support/matchers/type.rb +0 -19
- data/spec/support/matchers.rb +0 -3
- data/spec/support/vcr_setup.rb +0 -25
- data/spec/vcr_cassettes/articles/all.yml +0 -67
- data/spec/vcr_cassettes/articles/find_by_hash_failure.yml +0 -62
- data/spec/vcr_cassettes/articles/find_failure.yml +0 -62
- data/spec/vcr_cassettes/articles/find_id_1.yml +0 -63
- data/spec/vcr_cassettes/articles/find_new.yml +0 -63
- data/spec/vcr_cassettes/articles/limits/quantity_in_stock_min_value.yml +0 -63
- data/spec/vcr_cassettes/articles/limits/quantity_in_stock_rounding_positive_value.yml +0 -63
- data/spec/vcr_cassettes/articles/multi_param_find_by_hash.yml +0 -62
- data/spec/vcr_cassettes/articles/save_new.yml +0 -63
- data/spec/vcr_cassettes/articles/save_old.yml +0 -63
- data/spec/vcr_cassettes/articles/save_with_specially_named_attribute.yml +0 -63
- data/spec/vcr_cassettes/articles/search_by_name.yml +0 -65
- data/spec/vcr_cassettes/articles/search_miss.yml +0 -62
- data/spec/vcr_cassettes/articles/search_with_special_char.yml +0 -62
- data/spec/vcr_cassettes/articles/single_param_find_by_hash.yml +0 -62
- data/spec/vcr_cassettes/authentication/expired_token.yml +0 -54
- data/spec/vcr_cassettes/authentication/invalid_authorization.yml +0 -57
- data/spec/vcr_cassettes/authentication/invalid_refresh_token.yml +0 -58
- data/spec/vcr_cassettes/authentication/valid_request.yml +0 -63
- data/spec/vcr_cassettes/customers/all.yml +0 -69
- data/spec/vcr_cassettes/customers/find_by_hash_failure.yml +0 -62
- data/spec/vcr_cassettes/customers/find_failure.yml +0 -62
- data/spec/vcr_cassettes/customers/find_id_1.yml +0 -64
- data/spec/vcr_cassettes/customers/find_new.yml +0 -63
- data/spec/vcr_cassettes/customers/find_with_sales_account.yml +0 -63
- data/spec/vcr_cassettes/customers/multi_param_find_by_hash.yml +0 -63
- data/spec/vcr_cassettes/customers/save_new.yml +0 -63
- data/spec/vcr_cassettes/customers/save_new_with_country_code_SE.yml +0 -64
- data/spec/vcr_cassettes/customers/save_new_with_idn_email.yml +0 -67
- data/spec/vcr_cassettes/customers/save_new_with_sales_account.yml +0 -63
- data/spec/vcr_cassettes/customers/save_old.yml +0 -63
- data/spec/vcr_cassettes/customers/save_with_specially_named_attribute.yml +0 -63
- data/spec/vcr_cassettes/customers/search_by_name.yml +0 -64
- data/spec/vcr_cassettes/customers/search_miss.yml +0 -62
- data/spec/vcr_cassettes/customers/search_with_special_char.yml +0 -62
- data/spec/vcr_cassettes/customers/single_param_find_by_hash.yml +0 -64
- data/spec/vcr_cassettes/invoices/all.yml +0 -96
- data/spec/vcr_cassettes/invoices/filter_hit.yml +0 -64
- data/spec/vcr_cassettes/invoices/filter_invalid.yml +0 -60
- data/spec/vcr_cassettes/invoices/find_by_hash_failure.yml +0 -62
- data/spec/vcr_cassettes/invoices/find_failure.yml +0 -62
- data/spec/vcr_cassettes/invoices/find_id_1.yml +0 -65
- data/spec/vcr_cassettes/invoices/find_new.yml +0 -65
- data/spec/vcr_cassettes/invoices/multi_param_find_by_hash.yml +0 -63
- data/spec/vcr_cassettes/invoices/row_delivered_quantity_decimals.yml +0 -65
- data/spec/vcr_cassettes/invoices/row_delivered_quantity_decimals_round_up.yml +0 -65
- data/spec/vcr_cassettes/invoices/row_description_limit.yml +0 -65
- data/spec/vcr_cassettes/invoices/row_price_limit.yml +0 -65
- data/spec/vcr_cassettes/invoices/row_price_limit_round_up.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_comments.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_country.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_country_GB.yml +0 -66
- data/spec/vcr_cassettes/invoices/save_new_with_country_Norge.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_country_Norway.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_country_Sverige.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_country_VA.yml +0 -66
- data/spec/vcr_cassettes/invoices/save_new_with_country_VI.yml +0 -66
- data/spec/vcr_cassettes/invoices/save_new_with_country_empty_string.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_country_nil.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_new_with_unsaved_parent.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_old.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_old_with_empty_comments.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_old_with_empty_country.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_old_with_nil_comments.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_old_with_nil_country.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_with_nested_model.yml +0 -65
- data/spec/vcr_cassettes/invoices/save_with_specially_named_attribute.yml +0 -65
- data/spec/vcr_cassettes/invoices/search_by_name.yml +0 -63
- data/spec/vcr_cassettes/invoices/search_miss.yml +0 -62
- data/spec/vcr_cassettes/invoices/search_with_special_char.yml +0 -62
- data/spec/vcr_cassettes/invoices/single_param_find_by_hash.yml +0 -64
- data/spec/vcr_cassettes/orders/all.yml +0 -69
- data/spec/vcr_cassettes/orders/filter_hit.yml +0 -64
- data/spec/vcr_cassettes/orders/filter_invalid.yml +0 -60
- data/spec/vcr_cassettes/orders/find_by_hash_failure.yml +0 -62
- data/spec/vcr_cassettes/orders/find_failure.yml +0 -62
- data/spec/vcr_cassettes/orders/find_id_1.yml +0 -67
- data/spec/vcr_cassettes/orders/find_new.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_invalid_tax_reduction_type.yml +0 -61
- data/spec/vcr_cassettes/orders/housework_othercoses_invalid.yml +0 -61
- data/spec/vcr_cassettes/orders/housework_type_babysitting.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_cleaning.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_construction.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_cooking.yml +0 -61
- data/spec/vcr_cassettes/orders/housework_type_electricity.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_gardening.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_glassmetalwork.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_grounddrainagework.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_hvac.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_itservices.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_majorappliancerepair.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_masonry.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_movingservices.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_othercare.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_othercosts.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_paintingwallpapering.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_snowplowing.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_textileclothing.yml +0 -65
- data/spec/vcr_cassettes/orders/housework_type_tutoring.yml +0 -61
- data/spec/vcr_cassettes/orders/multi_param_find_by_hash.yml +0 -63
- data/spec/vcr_cassettes/orders/save_new.yml +0 -65
- data/spec/vcr_cassettes/orders/save_old.yml +0 -65
- data/spec/vcr_cassettes/orders/save_with_nested_model.yml +0 -65
- data/spec/vcr_cassettes/orders/search_by_name.yml +0 -63
- data/spec/vcr_cassettes/orders/search_miss.yml +0 -62
- data/spec/vcr_cassettes/orders/search_with_special_char.yml +0 -62
- data/spec/vcr_cassettes/orders/single_param_find_by_hash.yml +0 -64
- data/spec/vcr_cassettes/projects/all.yml +0 -64
- data/spec/vcr_cassettes/projects/find_by_hash_failure.yml +0 -62
- data/spec/vcr_cassettes/projects/find_failure.yml +0 -62
- data/spec/vcr_cassettes/projects/find_id_1.yml +0 -63
- data/spec/vcr_cassettes/projects/find_new.yml +0 -63
- data/spec/vcr_cassettes/projects/multi_param_find_by_hash.yml +0 -64
- data/spec/vcr_cassettes/projects/save_new.yml +0 -63
- data/spec/vcr_cassettes/projects/save_old.yml +0 -63
- data/spec/vcr_cassettes/projects/single_param_find_by_hash.yml +0 -63
- data/spec/vcr_cassettes/termsofpayments/all.yml +0 -68
- data/spec/vcr_cassettes/termsofpayments/find_failure.yml +0 -62
- data/spec/vcr_cassettes/termsofpayments/find_id_1.yml +0 -62
- data/spec/vcr_cassettes/termsofpayments/find_new.yml +0 -63
- data/spec/vcr_cassettes/termsofpayments/save_new.yml +0 -63
- data/spec/vcr_cassettes/termsofpayments/save_old.yml +0 -63
- data/spec/vcr_cassettes/units/all.yml +0 -64
- data/spec/vcr_cassettes/units/find_failure.yml +0 -62
- data/spec/vcr_cassettes/units/find_id_1.yml +0 -63
- data/spec/vcr_cassettes/units/find_new.yml +0 -63
- data/spec/vcr_cassettes/units/save_new.yml +0 -63
- data/spec/vcr_cassettes/units/save_old.yml +0 -63
- data/spec/vcr_cassettes/units/save_with_specially_named_attribute.yml +0 -63
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api'
|
|
5
|
-
require 'fortnox/api/mappers/order'
|
|
6
|
-
require 'fortnox/api/mappers/examples/mapper'
|
|
7
|
-
|
|
8
|
-
describe Fortnox::API::Mapper::Order do
|
|
9
|
-
key_map =
|
|
10
|
-
{
|
|
11
|
-
administration_fee_vat: 'AdministrationFeeVAT',
|
|
12
|
-
freight_vat: 'FreightVAT',
|
|
13
|
-
housework: 'HouseWork',
|
|
14
|
-
total_vat: 'TotalVAT',
|
|
15
|
-
vat_included: 'VATIncluded'
|
|
16
|
-
}
|
|
17
|
-
json_entity_type = 'Order'
|
|
18
|
-
json_entity_collection = 'Orders'
|
|
19
|
-
|
|
20
|
-
it_behaves_like 'mapper', key_map, json_entity_type, json_entity_collection do
|
|
21
|
-
let(:mapper) { described_class.new }
|
|
22
|
-
end
|
|
23
|
-
end
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api'
|
|
5
|
-
require 'fortnox/api/mappers/project'
|
|
6
|
-
require 'fortnox/api/mappers/examples/mapper'
|
|
7
|
-
|
|
8
|
-
describe Fortnox::API::Mapper::Project do
|
|
9
|
-
it_behaves_like 'mapper', {}, 'Project', 'Projects' do
|
|
10
|
-
let(:mapper) { described_class.new }
|
|
11
|
-
end
|
|
12
|
-
end
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api'
|
|
5
|
-
require 'fortnox/api/mappers/terms_of_payment'
|
|
6
|
-
require 'fortnox/api/mappers/examples/mapper'
|
|
7
|
-
|
|
8
|
-
describe Fortnox::API::Mapper::TermsOfPayment do
|
|
9
|
-
key_map = {}
|
|
10
|
-
json_entity_type = 'TermsOfPayment'
|
|
11
|
-
json_entity_collection = 'TermsOfPayments'
|
|
12
|
-
|
|
13
|
-
it_behaves_like 'mapper', key_map, json_entity_type, json_entity_collection do
|
|
14
|
-
let(:mapper) { described_class.new }
|
|
15
|
-
end
|
|
16
|
-
end
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api'
|
|
5
|
-
require 'fortnox/api/mappers/unit'
|
|
6
|
-
require 'fortnox/api/models/unit'
|
|
7
|
-
require 'fortnox/api/mappers/examples/mapper'
|
|
8
|
-
|
|
9
|
-
module Fortnox
|
|
10
|
-
module API
|
|
11
|
-
module Mapper
|
|
12
|
-
describe Unit do
|
|
13
|
-
context 'when mapping model' do
|
|
14
|
-
let(:model) { Model::Unit.new(code: 'lbs', description: 'Pounds') }
|
|
15
|
-
let(:serialised_model_hash) { { 'Unit' => { 'Code' => 'lbs', 'Description' => 'Pounds' } } }
|
|
16
|
-
let(:model_hash) { { code: 'lbs', description: 'Pounds' } }
|
|
17
|
-
|
|
18
|
-
describe '#entity_to_hash' do
|
|
19
|
-
subject { described_class.new.entity_to_hash(model, {}) }
|
|
20
|
-
|
|
21
|
-
it { is_expected.to eq(serialised_model_hash) }
|
|
22
|
-
end
|
|
23
|
-
|
|
24
|
-
describe '#wrapped_json_hash_to_entity_hash' do
|
|
25
|
-
subject { described_class.new.wrapped_json_hash_to_entity_hash(serialised_model_hash) }
|
|
26
|
-
|
|
27
|
-
it { is_expected.to eq(model_hash) }
|
|
28
|
-
end
|
|
29
|
-
end
|
|
30
|
-
|
|
31
|
-
context 'when mapping collection' do
|
|
32
|
-
let(:serialised_collection_hash) do
|
|
33
|
-
{ 'Units' => [
|
|
34
|
-
{ 'Unit' => { 'Code' => 'lbs', 'Description' => 'Pounds' } },
|
|
35
|
-
{ 'Unit' => { 'Code' => 'ohm', 'Description' => 'Ω' } },
|
|
36
|
-
{ 'Unit' => { 'Code' => 'A/V', 'Description' => 'Ampere volt' } }
|
|
37
|
-
] }
|
|
38
|
-
end
|
|
39
|
-
let(:collection_hash) do
|
|
40
|
-
[
|
|
41
|
-
{ unit: { code: 'lbs', description: 'Pounds' } },
|
|
42
|
-
{ unit: { code: 'ohm', description: 'Ω' } },
|
|
43
|
-
{ unit: { code: 'A/V', description: 'Ampere volt' } }
|
|
44
|
-
]
|
|
45
|
-
end
|
|
46
|
-
|
|
47
|
-
describe '#wrapped_json_collection_to_entities_hash' do
|
|
48
|
-
subject { described_class.new.wrapped_json_collection_to_entities_hash(serialised_collection_hash) }
|
|
49
|
-
|
|
50
|
-
it { is_expected.to eq(collection_hash) }
|
|
51
|
-
end
|
|
52
|
-
end
|
|
53
|
-
end
|
|
54
|
-
end
|
|
55
|
-
end
|
|
56
|
-
end
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api/models/base'
|
|
5
|
-
require 'fortnox/api/types'
|
|
6
|
-
|
|
7
|
-
describe Fortnox::API::Model::Base do
|
|
8
|
-
let(:entity_class) do
|
|
9
|
-
Class.new(Fortnox::API::Model::Base) do
|
|
10
|
-
attribute :private, Fortnox::API::Types::String.is(:read_only)
|
|
11
|
-
attribute :string, Fortnox::API::Types::Required::String
|
|
12
|
-
attribute :number, Fortnox::API::Types::Nullable::Integer
|
|
13
|
-
attribute :account, Fortnox::API::Types::AccountNumber
|
|
14
|
-
end
|
|
15
|
-
end
|
|
16
|
-
|
|
17
|
-
describe '.new' do
|
|
18
|
-
context 'with basic attribute' do
|
|
19
|
-
subject { entity_class.new(string: 'Test') }
|
|
20
|
-
|
|
21
|
-
it { is_expected.to be_a entity_class }
|
|
22
|
-
it { is_expected.to be_new }
|
|
23
|
-
it { is_expected.not_to be_saved }
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
context 'without required attribute' do
|
|
27
|
-
it do
|
|
28
|
-
expect do
|
|
29
|
-
entity_class.new({})
|
|
30
|
-
end.to raise_error Fortnox::API::MissingAttributeError, /Missing attribute :string/
|
|
31
|
-
end
|
|
32
|
-
end
|
|
33
|
-
|
|
34
|
-
context 'with invalid attribute value' do
|
|
35
|
-
it do
|
|
36
|
-
expect do
|
|
37
|
-
entity_class.new(string: 'Test', account: 13_337)
|
|
38
|
-
end.to raise_error Fortnox::API::AttributeError, /invalid type for :account/
|
|
39
|
-
end
|
|
40
|
-
end
|
|
41
|
-
end
|
|
42
|
-
|
|
43
|
-
describe '.update' do
|
|
44
|
-
let(:original) { entity_class.new(string: 'Test') }
|
|
45
|
-
|
|
46
|
-
context 'with new, simple value' do
|
|
47
|
-
subject(:updated_model) { original.update(string: 'Variant') }
|
|
48
|
-
|
|
49
|
-
it { is_expected.to be_new }
|
|
50
|
-
it { is_expected.not_to be_saved }
|
|
51
|
-
|
|
52
|
-
it 'returns a new object' do
|
|
53
|
-
expect(updated_model).not_to eql(original)
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
describe 'updated attribute' do
|
|
57
|
-
subject { updated_model.string }
|
|
58
|
-
|
|
59
|
-
it { is_expected.to eql('Variant') }
|
|
60
|
-
end
|
|
61
|
-
|
|
62
|
-
describe 'returned class' do
|
|
63
|
-
subject { updated_model.class }
|
|
64
|
-
|
|
65
|
-
it { is_expected.to eql(original.class) }
|
|
66
|
-
end
|
|
67
|
-
end
|
|
68
|
-
|
|
69
|
-
context 'with the same, simple value' do
|
|
70
|
-
subject(:updated_model) { original.update(string: 'Test') }
|
|
71
|
-
|
|
72
|
-
it 'returns the same object' do
|
|
73
|
-
expect(updated_model).to eql(original)
|
|
74
|
-
end
|
|
75
|
-
|
|
76
|
-
it 'returns a object with the same value' do
|
|
77
|
-
expect(updated_model.string).to eql('Test')
|
|
78
|
-
end
|
|
79
|
-
|
|
80
|
-
it { is_expected.to be_new }
|
|
81
|
-
it { is_expected.not_to be_saved }
|
|
82
|
-
end
|
|
83
|
-
|
|
84
|
-
context 'when updating a saved entity' do
|
|
85
|
-
let(:updated_entity) do
|
|
86
|
-
saved_entity = entity_class.new(string: 'Saved', new: false, unsaved: false)
|
|
87
|
-
saved_entity.update(string: 'Updated')
|
|
88
|
-
end
|
|
89
|
-
|
|
90
|
-
describe 'updated entity' do
|
|
91
|
-
subject { updated_entity }
|
|
92
|
-
|
|
93
|
-
it { is_expected.not_to be_saved }
|
|
94
|
-
it { is_expected.not_to be_new }
|
|
95
|
-
end
|
|
96
|
-
|
|
97
|
-
describe 'updated attribute value' do
|
|
98
|
-
subject { updated_entity.string }
|
|
99
|
-
|
|
100
|
-
it { is_expected.to eq('Updated') }
|
|
101
|
-
end
|
|
102
|
-
end
|
|
103
|
-
|
|
104
|
-
context 'when updating a saved entity with nil values' do
|
|
105
|
-
subject(:updated_entity) { original.update(number: nil) }
|
|
106
|
-
|
|
107
|
-
let(:original) { entity_class.new(string: 'Saved', new: false, unsaved: false) }
|
|
108
|
-
|
|
109
|
-
it 'returns the same object' do
|
|
110
|
-
expect(updated_entity).to eql(original)
|
|
111
|
-
end
|
|
112
|
-
|
|
113
|
-
it { is_expected.not_to be_new }
|
|
114
|
-
it { is_expected.to be_saved }
|
|
115
|
-
end
|
|
116
|
-
end
|
|
117
|
-
end
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'fortnox/api/models/examples/model'
|
|
4
|
-
|
|
5
|
-
shared_examples_for 'DocumentBase Model' do |row_class, row_attribute, valid_row_hash: {}|
|
|
6
|
-
it_behaves_like 'a model', 1
|
|
7
|
-
|
|
8
|
-
context "when having a(n) #{row_class}" do
|
|
9
|
-
it 'returns the correct object' do
|
|
10
|
-
row = row_class.new(valid_row_hash)
|
|
11
|
-
document = described_class.new(customer_number: '123', row_attribute => [row])
|
|
12
|
-
expect(document.send(row_attribute)).to eq([row])
|
|
13
|
-
end
|
|
14
|
-
end
|
|
15
|
-
end
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
shared_examples_for 'a model' do |unique_id|
|
|
4
|
-
let(:required_attributes) { described_class::STUB.dup }
|
|
5
|
-
let(:unique_id_attribute) { described_class::UNIQUE_ID }
|
|
6
|
-
|
|
7
|
-
it 'can be initialized' do
|
|
8
|
-
expect { described_class.new(required_attributes) }.not_to raise_error
|
|
9
|
-
end
|
|
10
|
-
|
|
11
|
-
describe '.unique_id' do
|
|
12
|
-
subject { model.unique_id }
|
|
13
|
-
|
|
14
|
-
let(:model) do
|
|
15
|
-
described_class.new(
|
|
16
|
-
required_attributes.merge(unique_id_attribute => unique_id)
|
|
17
|
-
)
|
|
18
|
-
end
|
|
19
|
-
|
|
20
|
-
it { is_expected.to eq unique_id }
|
|
21
|
-
end
|
|
22
|
-
end
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api/models/invoice'
|
|
5
|
-
require 'fortnox/api/models/examples/document_base'
|
|
6
|
-
|
|
7
|
-
describe Fortnox::API::Model::Invoice, type: :model do
|
|
8
|
-
it_behaves_like 'DocumentBase Model',
|
|
9
|
-
Fortnox::API::Types::InvoiceRow,
|
|
10
|
-
:invoice_rows
|
|
11
|
-
end
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api/models/order'
|
|
5
|
-
require 'fortnox/api/models/examples/document_base'
|
|
6
|
-
|
|
7
|
-
describe Fortnox::API::Model::Order, type: :model do
|
|
8
|
-
it_behaves_like 'DocumentBase Model',
|
|
9
|
-
Fortnox::API::Types::OrderRow,
|
|
10
|
-
:order_rows,
|
|
11
|
-
valid_row_hash: { ordered_quantity: 1.1 }
|
|
12
|
-
end
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api/models/unit'
|
|
5
|
-
|
|
6
|
-
module Fortnox
|
|
7
|
-
module API
|
|
8
|
-
# Shhh Rubocop, we don't need a comment here ... Really
|
|
9
|
-
module Model
|
|
10
|
-
describe Unit, type: :model do
|
|
11
|
-
context 'when created from empty hash' do
|
|
12
|
-
it {
|
|
13
|
-
expect do
|
|
14
|
-
described_class.new
|
|
15
|
-
end.to raise_error(Fortnox::API::MissingAttributeError, /Missing attribute.*:code/)
|
|
16
|
-
}
|
|
17
|
-
end
|
|
18
|
-
|
|
19
|
-
context 'when created from stub' do
|
|
20
|
-
subject { described_class.stub }
|
|
21
|
-
|
|
22
|
-
it { is_expected.to have_attributes(code: '', description: nil) }
|
|
23
|
-
end
|
|
24
|
-
|
|
25
|
-
context 'when created with all attributes' do
|
|
26
|
-
subject { described_class.new(code: 'lbs', description: 'Pounds') }
|
|
27
|
-
|
|
28
|
-
it { is_expected.to have_attributes(code: 'lbs', description: 'Pounds') }
|
|
29
|
-
end
|
|
30
|
-
end
|
|
31
|
-
end
|
|
32
|
-
end
|
|
33
|
-
end
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api'
|
|
5
|
-
require 'fortnox/api/mappers'
|
|
6
|
-
require 'fortnox/api/repositories/customer'
|
|
7
|
-
require 'fortnox/api/repositories/examples/all'
|
|
8
|
-
require 'fortnox/api/repositories/examples/find'
|
|
9
|
-
require 'fortnox/api/repositories/examples/save'
|
|
10
|
-
require 'fortnox/api/repositories/examples/save_with_specially_named_attribute'
|
|
11
|
-
require 'fortnox/api/repositories/examples/search'
|
|
12
|
-
|
|
13
|
-
describe Fortnox::API::Repository::Article, integration: true, order: :defined do
|
|
14
|
-
include Helpers::Configuration
|
|
15
|
-
include Helpers::Repositories
|
|
16
|
-
|
|
17
|
-
subject(:repository) { described_class.new }
|
|
18
|
-
|
|
19
|
-
before { set_api_test_configuration }
|
|
20
|
-
|
|
21
|
-
# VCR: Requires a Financial Year in Fortnox, otherwise the sales account is not be available.
|
|
22
|
-
# VCR: Update requires that default accounts exists in the chart of accounts
|
|
23
|
-
include_examples '.save',
|
|
24
|
-
:description,
|
|
25
|
-
additional_attrs: { sales_account: 1250 }
|
|
26
|
-
|
|
27
|
-
include_examples '.save with specially named attribute',
|
|
28
|
-
{ description: 'Test article' },
|
|
29
|
-
:ean,
|
|
30
|
-
'5901234123457'
|
|
31
|
-
|
|
32
|
-
# VCR: expected matches must be increased
|
|
33
|
-
include_examples '.all', 6
|
|
34
|
-
|
|
35
|
-
# VCR: Expected matches must be increased
|
|
36
|
-
# VCR: Create the searched Articles manually in Fortnox
|
|
37
|
-
include_examples '.find', '1' do
|
|
38
|
-
let(:find_by_hash_failure) { { description: 'Not Found' } }
|
|
39
|
-
let(:single_param_find_by_hash) { { find_hash: { articlenumber: 101 }, matches: 1 } }
|
|
40
|
-
|
|
41
|
-
let(:multi_param_find_by_hash) do
|
|
42
|
-
{ find_hash: { articlenumber: 101, description: 'Hammer' }, matches: 1 }
|
|
43
|
-
end
|
|
44
|
-
end
|
|
45
|
-
|
|
46
|
-
# VCR: Expected mathes must be updated
|
|
47
|
-
include_examples '.search', :description, 'Test article', 3
|
|
48
|
-
|
|
49
|
-
describe 'limits' do
|
|
50
|
-
let(:article) do
|
|
51
|
-
VCR.use_cassette("#{vcr_dir}/#{cassette}") do
|
|
52
|
-
repository.save(described_class::MODEL.new(**attributes))
|
|
53
|
-
end
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
describe 'quantity_in_stock' do
|
|
57
|
-
let(:cassette) { 'limits/quantity_in_stock_min_value' }
|
|
58
|
-
let(:attributes) do
|
|
59
|
-
{
|
|
60
|
-
description: 'Test article',
|
|
61
|
-
quantity_in_stock: quantity_in_stock
|
|
62
|
-
}
|
|
63
|
-
end
|
|
64
|
-
let(:quantity_in_stock) { -99_999_999_999_999.9 }
|
|
65
|
-
|
|
66
|
-
it 'has a lower limit' do
|
|
67
|
-
expect(article.quantity_in_stock).to eq(-100_000_000_000_000.0)
|
|
68
|
-
end
|
|
69
|
-
|
|
70
|
-
context 'when positive' do
|
|
71
|
-
let(:cassette) { 'limits/quantity_in_stock_rounding_positive_value' }
|
|
72
|
-
let(:quantity_in_stock) { 1.123 }
|
|
73
|
-
|
|
74
|
-
it 'rounds to two decimals' do
|
|
75
|
-
expect(article.quantity_in_stock).to eq(1.12)
|
|
76
|
-
end
|
|
77
|
-
end
|
|
78
|
-
end
|
|
79
|
-
end
|
|
80
|
-
end
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
# frozen_string_literal: true
|
|
2
|
-
|
|
3
|
-
require 'spec_helper'
|
|
4
|
-
require 'fortnox/api'
|
|
5
|
-
require 'fortnox/api/repositories/authentication'
|
|
6
|
-
|
|
7
|
-
describe Fortnox::API::Repository::Authentication, integration: true do
|
|
8
|
-
include Helpers::Configuration
|
|
9
|
-
|
|
10
|
-
subject(:repository) { described_class.new }
|
|
11
|
-
|
|
12
|
-
before { set_api_test_configuration }
|
|
13
|
-
|
|
14
|
-
let(:vcr_dir) { 'authentication' }
|
|
15
|
-
|
|
16
|
-
let(:valid_response) do
|
|
17
|
-
VCR.use_cassette("#{vcr_dir}/valid_request") do
|
|
18
|
-
repository.renew_tokens(
|
|
19
|
-
refresh_token: ENV.fetch('FORTNOX_API_REFRESH_TOKEN'),
|
|
20
|
-
client_id: ENV.fetch('FORTNOX_API_CLIENT_ID'),
|
|
21
|
-
client_secret: ENV.fetch('FORTNOX_API_CLIENT_SECRET')
|
|
22
|
-
)
|
|
23
|
-
end
|
|
24
|
-
end
|
|
25
|
-
|
|
26
|
-
describe '#renew_tokens' do
|
|
27
|
-
context 'with invalid authorization' do
|
|
28
|
-
let(:request_with_nonsense_credentials) do
|
|
29
|
-
VCR.use_cassette("#{vcr_dir}/invalid_authorization") do
|
|
30
|
-
repository.renew_tokens(
|
|
31
|
-
refresh_token: ENV.fetch('FORTNOX_API_REFRESH_TOKEN'),
|
|
32
|
-
client_id: 'nonsense_id',
|
|
33
|
-
client_secret: 'nonsense_secret'
|
|
34
|
-
)
|
|
35
|
-
end
|
|
36
|
-
end
|
|
37
|
-
|
|
38
|
-
it 'raises an error' do
|
|
39
|
-
expect { request_with_nonsense_credentials }.to(
|
|
40
|
-
raise_error(Fortnox::API::RemoteServerError, /Unauthorized request(.)*Error:(.)*invalid_client/)
|
|
41
|
-
)
|
|
42
|
-
end
|
|
43
|
-
end
|
|
44
|
-
|
|
45
|
-
context 'with invalid refresh token' do
|
|
46
|
-
let(:request_with_invalid_refresh_token) do
|
|
47
|
-
VCR.use_cassette("#{vcr_dir}/invalid_refresh_token") do
|
|
48
|
-
repository.renew_tokens(
|
|
49
|
-
refresh_token: 'invalid_refresh_token',
|
|
50
|
-
client_id: ENV.fetch('FORTNOX_API_CLIENT_ID'),
|
|
51
|
-
client_secret: ENV.fetch('FORTNOX_API_CLIENT_SECRET')
|
|
52
|
-
)
|
|
53
|
-
end
|
|
54
|
-
end
|
|
55
|
-
|
|
56
|
-
it 'raises an error' do
|
|
57
|
-
expect { request_with_invalid_refresh_token }.to(
|
|
58
|
-
raise_error(Fortnox::API::RemoteServerError, /Bad request(.)*Error:(.)*Invalid refresh token/)
|
|
59
|
-
)
|
|
60
|
-
end
|
|
61
|
-
end
|
|
62
|
-
|
|
63
|
-
describe 'returned hash' do
|
|
64
|
-
subject { valid_response }
|
|
65
|
-
|
|
66
|
-
it { is_expected.to include(:access_token, :refresh_token, :expires_in, :token_type, :scope) }
|
|
67
|
-
end
|
|
68
|
-
|
|
69
|
-
describe 'access_token' do
|
|
70
|
-
subject { valid_response[:access_token] }
|
|
71
|
-
|
|
72
|
-
it { is_expected.to be_a(String) }
|
|
73
|
-
it { is_expected.not_to be_empty }
|
|
74
|
-
end
|
|
75
|
-
|
|
76
|
-
describe 'refresh_token' do
|
|
77
|
-
subject { valid_response[:refresh_token] }
|
|
78
|
-
|
|
79
|
-
it { is_expected.to be_a(String) }
|
|
80
|
-
it { is_expected.not_to be_empty }
|
|
81
|
-
end
|
|
82
|
-
|
|
83
|
-
describe 'expires_in' do
|
|
84
|
-
subject { valid_response[:expires_in] }
|
|
85
|
-
|
|
86
|
-
it { is_expected.to be_a(Integer) }
|
|
87
|
-
end
|
|
88
|
-
|
|
89
|
-
describe 'token_type' do
|
|
90
|
-
subject { valid_response[:token_type] }
|
|
91
|
-
|
|
92
|
-
it { is_expected.to be_a(String) }
|
|
93
|
-
it { is_expected.not_to be_empty }
|
|
94
|
-
end
|
|
95
|
-
|
|
96
|
-
describe 'scope' do
|
|
97
|
-
subject { valid_response[:scope] }
|
|
98
|
-
|
|
99
|
-
it { is_expected.to be_a(String) }
|
|
100
|
-
it { is_expected.not_to be_empty }
|
|
101
|
-
end
|
|
102
|
-
end
|
|
103
|
-
end
|