dorsale 1.2.6 → 2.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/javascripts/accounting.js +413 -0
- data/app/assets/javascripts/dorsale/billing_machine/all.coffee +20 -0
- data/app/assets/javascripts/dorsale/billing_machine/invoices.coffee +39 -0
- data/app/assets/javascripts/dorsale/billing_machine/quotations.coffee +38 -0
- data/app/assets/javascripts/dorsale/comments.coffee +4 -0
- data/app/assets/javascripts/dorsale/customer_vault/all.coffee +9 -0
- data/app/assets/javascripts/dorsale/datepicker.coffee +1 -1
- data/app/assets/javascripts/dorsale/flyboy/all.coffee +0 -0
- data/app/assets/javascripts/dorsale/forms.coffee +20 -6
- data/app/assets/stylesheets/dorsale/billing_machine/all.sass +15 -0
- data/app/assets/stylesheets/dorsale/bootstrap_nav_left.sass +34 -0
- data/app/assets/stylesheets/dorsale/comments.sass +25 -3
- data/app/assets/stylesheets/dorsale/customer_vault/all.sass +89 -0
- data/app/assets/stylesheets/dorsale/filters.sass +4 -1
- data/app/assets/stylesheets/dorsale/flyboy/all.sass +52 -0
- data/app/assets/stylesheets/dorsale/forms.sass +19 -0
- data/app/controllers/dorsale/alexandrie/attachments_controller.rb +52 -0
- data/app/controllers/dorsale/billing_machine/application_controller.rb +15 -0
- data/app/controllers/dorsale/billing_machine/invoices_controller.rb +180 -0
- data/app/controllers/dorsale/billing_machine/quotations_controller.rb +151 -0
- data/app/controllers/dorsale/comments_controller.rb +64 -17
- data/app/controllers/dorsale/customer_vault/application_controller.rb +26 -0
- data/app/controllers/dorsale/customer_vault/corporations_controller.rb +100 -0
- data/app/controllers/dorsale/customer_vault/individuals_controller.rb +104 -0
- data/app/controllers/dorsale/customer_vault/links_controller.rb +92 -0
- data/app/controllers/dorsale/customer_vault/people_controller.rb +42 -0
- data/app/controllers/dorsale/flyboy/application_controller.rb +9 -0
- data/app/controllers/dorsale/flyboy/folders_controller.rb +124 -0
- data/app/controllers/dorsale/flyboy/task_comments_controller.rb +29 -0
- data/app/controllers/dorsale/flyboy/tasks_controller.rb +171 -0
- data/app/controllers/dorsale/small_data/filters_controller.rb +7 -0
- data/app/helpers/dorsale/alexandrie/attachments_helper.rb +17 -0
- data/app/helpers/dorsale/all_helpers.rb +12 -9
- data/app/helpers/dorsale/button_helper.rb +23 -3
- data/app/helpers/dorsale/comments_helper.rb +4 -0
- data/app/helpers/dorsale/customer_vault/application_helper.rb +98 -0
- data/app/helpers/dorsale/flyboy/application_helper.rb +44 -0
- data/app/helpers/dorsale/form_helper.rb +7 -0
- data/app/helpers/dorsale/link_helper.rb +3 -2
- data/app/helpers/dorsale/routes_helper.rb +5 -3
- data/app/helpers/dorsale/text_helper.rb +28 -1
- data/app/models/dorsale/ability_helper.rb +7 -0
- data/app/models/dorsale/alexandrie/ability_helper.rb +9 -0
- data/app/models/dorsale/alexandrie/attachment.rb +18 -0
- data/app/models/dorsale/billing_machine/ability_helper.rb +10 -0
- data/app/models/dorsale/billing_machine/id_card.rb +18 -0
- data/app/models/dorsale/billing_machine/invoice.rb +126 -0
- data/app/models/dorsale/billing_machine/invoice_line.rb +27 -0
- data/app/models/dorsale/billing_machine/payment_term.rb +12 -0
- data/app/models/dorsale/billing_machine/quotation.rb +66 -0
- data/app/models/dorsale/billing_machine/quotation_line.rb +25 -0
- data/app/models/dorsale/billing_machine/small_data/filter_for_invoices.rb +21 -0
- data/app/models/dorsale/billing_machine/small_data/filter_for_quotations.rb +20 -0
- data/app/models/dorsale/billing_machine/small_data/filter_strategy_by_customer.rb +12 -0
- data/app/models/dorsale/billing_machine/small_data/filter_strategy_by_payment_status.rb +23 -0
- data/app/models/dorsale/billing_machine/small_data/filter_strategy_by_time_period.rb +27 -0
- data/app/models/dorsale/comment.rb +6 -2
- data/app/models/dorsale/customer_vault/ability_helper.rb +9 -0
- data/app/models/dorsale/customer_vault/corporation.rb +12 -0
- data/app/models/dorsale/customer_vault/individual.rb +17 -0
- data/app/models/dorsale/customer_vault/link.rb +10 -0
- data/app/models/dorsale/customer_vault/person.rb +35 -0
- data/app/models/dorsale/customer_vault/small_data/filter_for_people.rb +19 -0
- data/app/models/dorsale/customer_vault/small_data/filter_strategy_by_tags.rb +18 -0
- data/app/models/dorsale/flyboy/ability_helper.rb +41 -0
- data/app/models/dorsale/flyboy/folder.rb +77 -0
- data/app/models/dorsale/flyboy/small_data/filter_for_folders.rb +19 -0
- data/app/models/dorsale/flyboy/small_data/filter_for_tasks.rb +19 -0
- data/app/models/dorsale/flyboy/small_data/filter_strategy_by_done.rb +12 -0
- data/app/models/dorsale/flyboy/small_data/filter_strategy_by_nothing.rb +11 -0
- data/app/models/dorsale/flyboy/small_data/filter_strategy_by_status.rb +15 -0
- data/app/models/dorsale/flyboy/task.rb +97 -0
- data/app/models/dorsale/flyboy/task_comment.rb +35 -0
- data/app/pdfs/dorsale/billing_machine/invoice_pdf.rb +209 -0
- data/app/pdfs/dorsale/billing_machine/quotation_pdf.rb +53 -0
- data/app/pdfs/dorsale/flyboy/roadmap.rb +51 -0
- data/app/uploaders/dorsale/alexandrie/file_uploader.rb +6 -0
- data/app/uploaders/dorsale/file_uploader.rb +9 -0
- data/app/uploaders/dorsale/image_uploader.rb +7 -0
- data/app/views/dorsale/_contextual.html.slim +3 -0
- data/app/views/dorsale/alexandrie/attachments/_form.html.slim +13 -0
- data/app/views/dorsale/alexandrie/attachments/_form_and_list.html.slim +2 -0
- data/app/views/dorsale/alexandrie/attachments/_list.html.slim +7 -0
- data/app/views/dorsale/billing_machine/invoices/_data_context.html.slim +10 -0
- data/app/views/dorsale/billing_machine/invoices/_filters.html.slim +16 -0
- data/app/views/dorsale/billing_machine/invoices/_form.html.slim +62 -0
- data/app/views/dorsale/billing_machine/invoices/_line_fields.html.slim +23 -0
- data/app/views/dorsale/billing_machine/invoices/_list.html.slim +30 -0
- data/app/views/dorsale/billing_machine/invoices/edit.html.slim +2 -0
- data/app/views/dorsale/billing_machine/invoices/index.html.slim +15 -0
- data/app/views/dorsale/billing_machine/invoices/new.html.slim +2 -0
- data/app/views/dorsale/billing_machine/invoices/show.html.slim +53 -0
- data/app/views/dorsale/billing_machine/quotations/_data_context.html.slim +10 -0
- data/app/views/dorsale/billing_machine/quotations/_filters.html.slim +13 -0
- data/app/views/dorsale/billing_machine/quotations/_form.html.slim +55 -0
- data/app/views/dorsale/billing_machine/quotations/_line_fields.html.slim +23 -0
- data/app/views/dorsale/billing_machine/quotations/_list.html.slim +30 -0
- data/app/views/dorsale/billing_machine/quotations/edit.html.slim +2 -0
- data/app/views/dorsale/billing_machine/quotations/index.html.slim +14 -0
- data/app/views/dorsale/billing_machine/quotations/new.html.slim +2 -0
- data/app/views/dorsale/billing_machine/quotations/show.html.slim +61 -0
- data/app/views/dorsale/comments/_comment.html.slim +23 -9
- data/app/views/dorsale/comments/_comments.html.slim +2 -2
- data/app/views/dorsale/comments/_form.html.slim +1 -1
- data/app/views/dorsale/comments/_list.html.slim +2 -0
- data/app/views/dorsale/comments/edit.html.slim +5 -0
- data/app/views/dorsale/customer_vault/_breadcrumb.html.slim +4 -0
- data/app/views/dorsale/customer_vault/corporations/_context.html.slim +20 -0
- data/app/views/dorsale/customer_vault/corporations/_form.html.slim +21 -0
- data/app/views/dorsale/customer_vault/corporations/_list_details.html.slim +20 -0
- data/app/views/dorsale/customer_vault/corporations/edit.html.slim +14 -0
- data/app/views/dorsale/customer_vault/corporations/new.html.slim +14 -0
- data/app/views/dorsale/customer_vault/corporations/show.html.slim +1 -0
- data/app/views/dorsale/customer_vault/individuals/_context.html.slim +15 -0
- data/app/views/dorsale/customer_vault/individuals/_form.html.slim +22 -0
- data/app/views/dorsale/customer_vault/individuals/_list_details.html.slim +20 -0
- data/app/views/dorsale/customer_vault/individuals/edit.html.slim +14 -0
- data/app/views/dorsale/customer_vault/individuals/new.html.slim +14 -0
- data/app/views/dorsale/customer_vault/individuals/show.html.slim +1 -0
- data/app/views/dorsale/customer_vault/links/_title.html.slim +7 -0
- data/app/views/dorsale/customer_vault/links/edit.html.slim +19 -0
- data/app/views/dorsale/customer_vault/links/new.html.slim +15 -0
- data/app/views/dorsale/customer_vault/people/_activity_tab.html.slim +5 -0
- data/app/views/dorsale/customer_vault/people/_comment.html.slim +1 -0
- data/app/views/dorsale/customer_vault/people/_context.html.slim +4 -0
- data/app/views/dorsale/customer_vault/people/_data_context.html.slim +32 -0
- data/app/views/dorsale/customer_vault/people/_filters.html.slim +15 -0
- data/app/views/dorsale/customer_vault/people/_index_tabs.html.slim +7 -0
- data/app/views/dorsale/customer_vault/people/_links_tab.html.slim +16 -0
- data/app/views/dorsale/customer_vault/people/_new_people_contexts.html.slim +7 -0
- data/app/views/dorsale/customer_vault/people/_show.html.slim +31 -0
- data/app/views/dorsale/customer_vault/people/_tasks_tab.html.slim +1 -0
- data/app/views/dorsale/customer_vault/people/activity.slim +20 -0
- data/app/views/dorsale/customer_vault/people/list.html.slim +27 -0
- data/app/views/dorsale/flyboy/_filters.html.slim +12 -0
- data/app/views/dorsale/flyboy/folders/_actions.html.slim +15 -0
- data/app/views/dorsale/flyboy/folders/_context.html.slim +18 -0
- data/app/views/dorsale/flyboy/folders/_form.html.slim +22 -0
- data/app/views/dorsale/flyboy/folders/_list.html.slim +30 -0
- data/app/views/dorsale/flyboy/folders/edit.html.slim +2 -0
- data/app/views/dorsale/flyboy/folders/index.html.slim +8 -0
- data/app/views/dorsale/flyboy/folders/new.html.slim +2 -0
- data/app/views/dorsale/flyboy/folders/show.html.slim +9 -0
- data/app/views/dorsale/flyboy/task_comments/_list.html.slim +31 -0
- data/app/views/dorsale/flyboy/tasks/_actions.html.slim +9 -0
- data/app/views/dorsale/flyboy/tasks/_context.html.slim +15 -0
- data/app/views/dorsale/flyboy/tasks/_form.html.slim +29 -0
- data/app/views/dorsale/flyboy/tasks/_list.html.slim +43 -0
- data/app/views/dorsale/flyboy/tasks/_tasks_for_taskable.html.slim +6 -0
- data/app/views/dorsale/flyboy/tasks/edit.html.slim +2 -0
- data/app/views/dorsale/flyboy/tasks/index.html.slim +10 -0
- data/app/views/dorsale/flyboy/tasks/index.xls.erb +29 -0
- data/app/views/dorsale/flyboy/tasks/new.html.slim +2 -0
- data/app/views/dorsale/flyboy/tasks/show.html.slim +14 -0
- data/app/views/dorsale/search/_form.html.slim +6 -0
- data/config/locales/alexandrie.fr.yml +8 -0
- data/config/locales/billing_machine.fr.yml +50 -0
- data/config/locales/common.fr.yml +142 -0
- data/config/locales/customer_vault.fr.yml +69 -0
- data/config/locales/flyboy.fr.yml +66 -0
- data/config/locales/fr.yml +8 -87
- data/config/routes.rb +50 -1
- data/db/migrate/20141010140200_create_dorsale_addresses.rb +1 -1
- data/db/migrate/20150312083147_create_dorsale_comments.rb +3 -3
- data/db/migrate/20150616074852_create_dorsale_alexandrie_attachments.rb +9 -0
- data/db/migrate/20150622075000_create_flyboy.rb +50 -0
- data/db/migrate/20150622075038_create_billing_machine.rb +121 -0
- data/db/migrate/20150622105217_create_customer_vault.rb +49 -0
- data/db/migrate/20150623093218_dorsale_v2_changes.rb +68 -0
- data/db/migrate/20150625093326_billing_machine_quotations_add_expires_at.rb +5 -0
- data/db/migrate/20150625131155_billing_machine_add_tracking_ids.rb +6 -0
- data/lib/active_record_comma_type_cast.rb +12 -0
- data/lib/dorsale/alexandrie/prawn.rb +17 -0
- data/lib/dorsale/engine.rb +19 -0
- data/lib/dorsale/file_loader.rb +10 -0
- data/lib/dorsale/model_i18n.rb +21 -0
- data/lib/dorsale/model_to_s.rb +13 -0
- data/lib/dorsale/polymorphic_id.rb +2 -0
- data/lib/dorsale/version.rb +1 -1
- data/spec/controllers/dorsale/alexandrie/attachments_controller_spec.rb +47 -0
- data/spec/controllers/dorsale/comments_controller_spec.rb +45 -0
- data/spec/controllers/dorsale/customer_vault/corporations_controller_spec.rb +132 -0
- data/spec/controllers/dorsale/customer_vault/individuals_controller_spec.rb +130 -0
- data/spec/controllers/dorsale/customer_vault/people_controller_spec.rb +59 -0
- data/spec/controllers/dorsale/flyboy/folders_controller_spec.rb +111 -0
- data/spec/controllers/dorsale/flyboy/task_comments_controller_spec.rb +16 -0
- data/spec/controllers/dorsale/flyboy/tasks_controller_spec.rb +234 -0
- data/spec/dummy/app/assets/javascripts/application.coffee +10 -0
- data/spec/dummy/app/assets/stylesheets/application.sass +9 -0
- data/spec/dummy/app/controllers/application_controller.rb +4 -0
- data/spec/dummy/app/models/ability.rb +16 -0
- data/spec/dummy/app/models/dummy_model.rb +2 -0
- data/spec/dummy/app/views/layouts/application.html.erb +10 -3
- data/spec/dummy/config/application.rb +4 -2
- data/spec/dummy/db/development.sqlite3 +0 -0
- data/spec/dummy/db/migrate/20150616082916_create_dorsale_dummy_models.rb +8 -0
- data/spec/dummy/db/migrate/20150624081204_acts_as_taggable_on_migration.acts_as_taggable_on_engine.rb +31 -0
- data/spec/dummy/db/migrate/20150624081205_add_missing_unique_indices.acts_as_taggable_on_engine.rb +20 -0
- data/spec/dummy/db/migrate/20150624081206_add_taggings_counter_cache_to_tags.acts_as_taggable_on_engine.rb +15 -0
- data/spec/dummy/db/migrate/20150624081207_add_missing_taggable_index.acts_as_taggable_on_engine.rb +10 -0
- data/spec/dummy/db/migrate/20150624081208_change_collation_for_tag_names.acts_as_taggable_on_engine.rb +10 -0
- data/spec/dummy/db/schema.rb +243 -5
- data/spec/dummy/db/seed.rb +1 -0
- data/spec/dummy/db/test.sqlite3 +0 -0
- data/spec/dummy/log/development.log +227 -0
- data/spec/dummy/log/test.log +2740 -25
- data/spec/dummy/{app/assets/stylesheets/application.css → tmp/cache/assets/development/sprockets/13fe41fee1fe35b49d145bcc06610705} +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/2f5173deea6c795b8fdde723bb4b63af +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/357970feca3ac29060c1e3861e2c0953 +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/cffd775d018f68ce5dba1ee0d951a994 +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/d771ace226fc8215a3572e0aa35bb0d6 +0 -0
- data/spec/dummy/tmp/cache/assets/development/sprockets/f7cbd26ba1d28d48de824f0e94586655 +0 -0
- data/spec/factories/alexandrie_attachments.rb +12 -0
- data/spec/factories/billing_machine_id_cards.rb +26 -0
- data/spec/factories/billing_machine_invoice_lines.rb +11 -0
- data/spec/factories/billing_machine_invoices.rb +12 -0
- data/spec/factories/billing_machine_payment_terms.rb +5 -0
- data/spec/factories/billing_machine_quotation_lines.rb +12 -0
- data/spec/factories/billing_machine_quotations.rb +12 -0
- data/spec/factories/customer_vault_corporations.rb +14 -0
- data/spec/factories/customer_vault_individuals.rb +19 -0
- data/spec/factories/customer_vault_links.rb +7 -0
- data/spec/factories/dorsale_addresses.rb +6 -8
- data/spec/factories/dorsale_comments.rb +8 -0
- data/spec/factories/flyboy_folders.rb +7 -0
- data/spec/factories/flyboy_task_comments.rb +8 -0
- data/spec/factories/flyboy_tasks.rb +12 -0
- data/spec/files/pdf.pdf +0 -0
- data/spec/helpers/dorsale/flyboy/application_helper_spec.rb +91 -0
- data/spec/helpers/dorsale/link_helper_spec.rb +1 -0
- data/spec/helpers/dorsale/text_helper_spec.rb +33 -9
- data/spec/models/dorsale/ability_helper_spec.rb +11 -0
- data/spec/models/dorsale/alexandrie/ability_helper_spec.rb +10 -0
- data/spec/models/dorsale/alexandrie/attachment_spec.rb +12 -0
- data/spec/models/dorsale/billing_machine/id_card_spec.rb +12 -0
- data/spec/models/dorsale/billing_machine/invoice_line_spec.rb +50 -0
- data/spec/models/dorsale/billing_machine/invoice_spec.rb +156 -0
- data/spec/models/dorsale/billing_machine/quotation_line_spec.rb +36 -0
- data/spec/models/dorsale/billing_machine/quotation_spec.rb +91 -0
- data/spec/models/dorsale/comment_spec.rb +11 -0
- data/spec/models/dorsale/customer_vault/corporation_spec.rb +17 -0
- data/spec/models/dorsale/customer_vault/individual_spec.rb +17 -0
- data/spec/models/dorsale/customer_vault/link_spec.rb +12 -0
- data/spec/models/dorsale/customer_vault/person_spec.rb +44 -0
- data/spec/models/dorsale/flyboy/ability_spec.rb +148 -0
- data/spec/models/dorsale/flyboy/folder_spec.rb +103 -0
- data/spec/models/dorsale/flyboy/task_comment_spec.rb +52 -0
- data/spec/models/dorsale/flyboy/task_spec.rb +83 -0
- data/spec/pdfs/dorsale/billing_machine/invoice_pdf_spec.rb +252 -0
- data/spec/pdfs/dorsale/billing_machine/quotation_pdf_spec.rb +255 -0
- data/spec/rails_helper.rb +11 -11
- data/spec/routing/dorsale/alexandrie/attachments_routing_spec.rb +19 -0
- data/spec/routing/dorsale/billing_machine/invoices_routing_spec.rb +53 -0
- data/spec/routing/dorsale/billing_machine/quotations_routing_spec.rb +43 -0
- data/spec/routing/dorsale/comments_routing_spec.rb +25 -0
- data/spec/routing/dorsale/customer_vault/corporations_routing_spec.rb +66 -0
- data/spec/routing/dorsale/customer_vault/individual_routing_spec.rb +66 -0
- data/spec/routing/dorsale/customer_vault/people_routing_spec.rb +22 -0
- data/spec/routing/dorsale/flyboy/folders_routing_spec.rb +44 -0
- data/spec/routing/dorsale/flyboy/task_comments_routing_spec.rb +12 -0
- data/spec/routing/dorsale/flyboy/tasks_routing_spec.rb +44 -0
- data/spec/spec_helper.rb +0 -6
- metadata +439 -10
- data/MIT-LICENSE +0 -20
- data/README.rdoc +0 -3
- data/spec/dummy/app/assets/javascripts/application.js +0 -13
@@ -0,0 +1,10 @@
|
|
1
|
+
module Kernel
|
2
|
+
def dorsale_file
|
3
|
+
app_file = caller.first.split(":").first
|
4
|
+
app_root = ::Rails.application.root.to_s
|
5
|
+
relative_file = app_file.gsub(app_root, "")
|
6
|
+
dorsale_root = ::Dorsale::Engine.root.to_s
|
7
|
+
|
8
|
+
::File.join(dorsale_root, relative_file)
|
9
|
+
end
|
10
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module Dorsale
|
2
|
+
module ModelI18n
|
3
|
+
def t(*args)
|
4
|
+
self.class.human_attribute_name(*args)
|
5
|
+
end
|
6
|
+
|
7
|
+
def self.included(model)
|
8
|
+
model.instance_eval do
|
9
|
+
def t(*args)
|
10
|
+
if args.any?
|
11
|
+
human_attribute_name(*args)
|
12
|
+
else
|
13
|
+
model_name.human
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
ActiveRecord::Base.send(:include, ::Dorsale::ModelI18n)
|
data/lib/dorsale/version.rb
CHANGED
@@ -0,0 +1,47 @@
|
|
1
|
+
require "rails_helper"
|
2
|
+
|
3
|
+
describe Dorsale::Alexandrie::AttachmentsController, type: :controller do
|
4
|
+
routes { Dorsale::Engine.routes }
|
5
|
+
|
6
|
+
let(:uploaded_file){
|
7
|
+
path = Rails.root.join("../../spec/files/pdf.pdf").to_s
|
8
|
+
Rack::Test::UploadedFile.new(path, "application/pdf")
|
9
|
+
}
|
10
|
+
|
11
|
+
let(:valid_attributes){
|
12
|
+
attachable = DummyModel.create!(name: "A")
|
13
|
+
|
14
|
+
{
|
15
|
+
:attachable_id => attachable.id,
|
16
|
+
:attachable_type => attachable.class.to_s,
|
17
|
+
:file => uploaded_file,
|
18
|
+
}
|
19
|
+
}
|
20
|
+
|
21
|
+
describe "create" do
|
22
|
+
it "should create attachment" do
|
23
|
+
post :create, attachment: valid_attributes, back_url: "/"
|
24
|
+
expect(assigns(:attachment)).to be_persisted
|
25
|
+
end
|
26
|
+
|
27
|
+
it "should redirect to back_url" do
|
28
|
+
post :create, attachment: valid_attributes, back_url: "/"
|
29
|
+
expect(response).to redirect_to("/")
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
describe "destroy" do
|
34
|
+
it "should delete attachment" do
|
35
|
+
attachment = create(:alexandrie_attachment)
|
36
|
+
expect {
|
37
|
+
delete :destroy, id: attachment, back_url: "/"
|
38
|
+
}.to change(::Dorsale::Alexandrie::Attachment, :count).by(-1)
|
39
|
+
end
|
40
|
+
|
41
|
+
it "should redirect to back_url" do
|
42
|
+
attachment = create(:alexandrie_attachment)
|
43
|
+
delete :destroy, id: attachment, back_url: "/"
|
44
|
+
expect(response).to redirect_to("/")
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require "rails_helper"
|
2
|
+
|
3
|
+
describe Dorsale::CommentsController, type: :controller do
|
4
|
+
routes { Dorsale::Engine.routes }
|
5
|
+
|
6
|
+
|
7
|
+
let(:valid_attributes){
|
8
|
+
commentable = DummyModel.create!(name: "A")
|
9
|
+
|
10
|
+
{
|
11
|
+
:commentable_id => commentable.id,
|
12
|
+
:commentable_type => commentable.class.to_s,
|
13
|
+
:text => "Hello",
|
14
|
+
}
|
15
|
+
}
|
16
|
+
|
17
|
+
describe "create" do
|
18
|
+
it "should create comment" do
|
19
|
+
post :create, comment: valid_attributes, back_url: "/"
|
20
|
+
expect(assigns(:comment)).to be_persisted
|
21
|
+
end
|
22
|
+
|
23
|
+
it "should redirect to back_url" do
|
24
|
+
post :create, comment: valid_attributes, back_url: "/"
|
25
|
+
expect(response).to redirect_to("/")
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
describe "update" do
|
30
|
+
it "should update comment text" do
|
31
|
+
comment = create(:dorsale_comment)
|
32
|
+
patch :update, id: comment, comment: {text: "New-comment-text"}, back_url: "/"
|
33
|
+
expect(response).to redirect_to("/")
|
34
|
+
expect(comment.reload.text).to eq "New-comment-text"
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
describe "destroy" do
|
39
|
+
it "should destroy comment" do
|
40
|
+
comment = create(:dorsale_comment)
|
41
|
+
delete :destroy, id: comment, back_url: "/"
|
42
|
+
expect(response).to redirect_to("/")
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,132 @@
|
|
1
|
+
require "rails_helper"
|
2
|
+
|
3
|
+
RSpec.describe ::Dorsale::CustomerVault::CorporationsController, type: :controller do
|
4
|
+
|
5
|
+
routes { ::Dorsale::Engine.routes }
|
6
|
+
|
7
|
+
let(:valid_attributes) {
|
8
|
+
FactoryGirl.attributes_for(:customer_vault_corporation)
|
9
|
+
}
|
10
|
+
|
11
|
+
let(:invalid_attributes) {
|
12
|
+
{name: ""}
|
13
|
+
}
|
14
|
+
|
15
|
+
let(:valid_session) { {} }
|
16
|
+
|
17
|
+
describe "GET show" do
|
18
|
+
it "assigns the requested corporation as @corporation" do
|
19
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
20
|
+
get :show, {:id => corporation.to_param}, valid_session
|
21
|
+
expect(assigns(:corporation)).to eq(corporation)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
describe "GET new" do
|
26
|
+
it "assigns a new corporation as @corporation" do
|
27
|
+
get :new, {}, valid_session
|
28
|
+
expect(assigns(:corporation)).to be_a_new(::Dorsale::CustomerVault::Corporation)
|
29
|
+
expect(assigns(:corporation).address).to be_a_new(::Dorsale::Address)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
describe "GET edit" do
|
34
|
+
it "assigns the requested corporation as @corporation" do
|
35
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
36
|
+
get :edit, {:id => corporation.to_param}, valid_session
|
37
|
+
expect(assigns(:corporation)).to eq(corporation)
|
38
|
+
expect(assigns(:corporation).address).to be_a_new(Dorsale::Address)
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
describe "POST create" do
|
43
|
+
describe "with valid params" do
|
44
|
+
it "creates a new corporation" do
|
45
|
+
expect {
|
46
|
+
post :create, {:corporation => valid_attributes}, valid_session
|
47
|
+
}.to change(::Dorsale::CustomerVault::Corporation, :count).by(1)
|
48
|
+
end
|
49
|
+
|
50
|
+
it "assigns a newly created corporation as @corporation" do
|
51
|
+
post :create, {:corporation => valid_attributes}, valid_session
|
52
|
+
expect(assigns(:corporation)).to be_a(::Dorsale::CustomerVault::Corporation)
|
53
|
+
expect(assigns(:corporation)).to be_persisted
|
54
|
+
end
|
55
|
+
|
56
|
+
it "redirects to the created corporation" do
|
57
|
+
post :create, {:corporation => valid_attributes}, valid_session
|
58
|
+
expect(response).to redirect_to(::Dorsale::CustomerVault::Corporation.last)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
describe "with invalid params" do
|
63
|
+
it "assigns a newly created but unsaved corporation as @corporation" do
|
64
|
+
post :create, {:corporation => invalid_attributes}, valid_session
|
65
|
+
expect(assigns(:corporation)).to be_a_new(::Dorsale::CustomerVault::Corporation)
|
66
|
+
end
|
67
|
+
|
68
|
+
it "re-renders the 'new' template" do
|
69
|
+
post :create, {:corporation => invalid_attributes}, valid_session
|
70
|
+
expect(response).to render_template("new")
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
describe "PUT update" do
|
76
|
+
describe "with valid params" do
|
77
|
+
let(:new_attributes) {
|
78
|
+
{name: 'New name'}
|
79
|
+
}
|
80
|
+
|
81
|
+
it "updates the requested corporation" do
|
82
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
83
|
+
put :update, {:id => corporation.to_param, :corporation => new_attributes}, valid_session
|
84
|
+
corporation.reload
|
85
|
+
expect(corporation.name).to eq('New name')
|
86
|
+
end
|
87
|
+
|
88
|
+
it "assigns the requested corporation as @corporation" do
|
89
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
90
|
+
put :update, {:id => corporation.to_param, :corporation => valid_attributes}, valid_session
|
91
|
+
expect(assigns(:corporation)).to eq(corporation)
|
92
|
+
end
|
93
|
+
|
94
|
+
it "redirects to the corporation" do
|
95
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
96
|
+
put :update, {:id => corporation.to_param, :corporation => valid_attributes}, valid_session
|
97
|
+
expect(response).to redirect_to(corporation)
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
describe "with invalid params" do
|
102
|
+
it "assigns the corporation as @corporation" do
|
103
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
104
|
+
put :update, {:id => corporation.to_param, :corporation => invalid_attributes}, valid_session
|
105
|
+
expect(assigns(:corporation)).to eq(corporation)
|
106
|
+
end
|
107
|
+
|
108
|
+
it "re-renders the 'edit' template" do
|
109
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
110
|
+
put :update, {:id => corporation.to_param, :corporation => invalid_attributes}, valid_session
|
111
|
+
expect(response).to render_template("edit")
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
describe "DELETE destroy" do
|
117
|
+
it "destroys the requested corporation" do
|
118
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
119
|
+
expect {
|
120
|
+
delete :destroy, {:id => corporation.to_param}, valid_session
|
121
|
+
}.to change(::Dorsale::CustomerVault::Corporation, :count).by(-1)
|
122
|
+
end
|
123
|
+
|
124
|
+
it "redirects to the corporations list" do
|
125
|
+
corporation = ::Dorsale::CustomerVault::Corporation.create! valid_attributes
|
126
|
+
delete :destroy, {:id => corporation.to_param}, valid_session
|
127
|
+
expect(response).to redirect_to(customer_vault_people_path)
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
end
|
132
|
+
|
@@ -0,0 +1,130 @@
|
|
1
|
+
require "rails_helper"
|
2
|
+
|
3
|
+
|
4
|
+
RSpec.describe ::Dorsale::CustomerVault::IndividualsController, type: :controller do
|
5
|
+
|
6
|
+
routes { ::Dorsale::Engine.routes }
|
7
|
+
|
8
|
+
let(:valid_attributes) {
|
9
|
+
FactoryGirl.attributes_for(:customer_vault_individual)
|
10
|
+
}
|
11
|
+
|
12
|
+
let(:invalid_attributes) {
|
13
|
+
{ last_name: "" }
|
14
|
+
}
|
15
|
+
|
16
|
+
let(:valid_session) { {} }
|
17
|
+
|
18
|
+
describe "GET show" do
|
19
|
+
it "assigns the requested individual as @individual" do
|
20
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
21
|
+
get :show, {:id => individual.to_param}, valid_session
|
22
|
+
expect(assigns(:individual)).to eq(individual)
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
describe "GET new" do
|
27
|
+
it "assigns a new individual as @individual" do
|
28
|
+
get :new, {}, valid_session
|
29
|
+
expect(assigns(:individual)).to be_a_new(::Dorsale::CustomerVault::Individual)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
describe "GET edit" do
|
34
|
+
it "assigns the requested individual as @individual" do
|
35
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
36
|
+
get :edit, {:id => individual.to_param}, valid_session
|
37
|
+
expect(assigns(:individual)).to eq(individual)
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
describe "POST create" do
|
42
|
+
describe "with valid params" do
|
43
|
+
it "creates a new individual" do
|
44
|
+
expect {
|
45
|
+
post :create, {:individual => valid_attributes}, valid_session
|
46
|
+
}.to change(::Dorsale::CustomerVault::Individual, :count).by(1)
|
47
|
+
end
|
48
|
+
|
49
|
+
it "assigns a newly created individual as @individual" do
|
50
|
+
post :create, {:individual => valid_attributes}, valid_session
|
51
|
+
expect(assigns(:individual)).to be_a(::Dorsale::CustomerVault::Individual)
|
52
|
+
expect(assigns(:individual)).to be_persisted
|
53
|
+
end
|
54
|
+
|
55
|
+
it "redirects to the created individual" do
|
56
|
+
post :create, {:individual => valid_attributes}, valid_session
|
57
|
+
expect(response).to redirect_to(::Dorsale::CustomerVault::Individual.last)
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
describe "with invalid params" do
|
62
|
+
it "assigns a newly created but unsaved individual as @individual" do
|
63
|
+
post :create, {:individual => invalid_attributes}, valid_session
|
64
|
+
expect(assigns(:individual)).to be_a_new(::Dorsale::CustomerVault::Individual)
|
65
|
+
end
|
66
|
+
|
67
|
+
it "re-renders the 'new' template" do
|
68
|
+
post :create, {:individual => invalid_attributes}, valid_session
|
69
|
+
expect(response).to render_template("new")
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
describe "PUT update" do
|
75
|
+
describe "with valid params" do
|
76
|
+
let(:new_attributes) {
|
77
|
+
{first_name: "Stroumph"}
|
78
|
+
}
|
79
|
+
|
80
|
+
it "updates the requested individual" do
|
81
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
82
|
+
put :update, {:id => individual.to_param, :individual => new_attributes}, valid_session
|
83
|
+
individual.reload
|
84
|
+
expect(individual.first_name).to eq("Stroumph")
|
85
|
+
end
|
86
|
+
|
87
|
+
it "assigns the requested individual as @individual" do
|
88
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
89
|
+
put :update, {:id => individual.to_param, :individual => valid_attributes}, valid_session
|
90
|
+
expect(assigns(:individual)).to eq(individual)
|
91
|
+
end
|
92
|
+
|
93
|
+
it "redirects to the individual" do
|
94
|
+
individual =::Dorsale::CustomerVault::Individual.create! valid_attributes
|
95
|
+
put :update, {:id => individual.to_param, :individual => valid_attributes}, valid_session
|
96
|
+
expect(response).to redirect_to(individual)
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
describe "with invalid params" do
|
101
|
+
it "assigns the individual as @individual" do
|
102
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
103
|
+
put :update, {:id => individual.to_param, :individual => invalid_attributes}, valid_session
|
104
|
+
expect(assigns(:individual)).to eq(individual)
|
105
|
+
end
|
106
|
+
|
107
|
+
it "re-renders the 'edit' template" do
|
108
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
109
|
+
put :update, {:id => individual.to_param, :individual => invalid_attributes}, valid_session
|
110
|
+
expect(response).to render_template("edit")
|
111
|
+
end
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
describe "DELETE destroy" do
|
116
|
+
it "destroys the requested individual" do
|
117
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
118
|
+
expect {
|
119
|
+
delete :destroy, {:id => individual.to_param}, valid_session
|
120
|
+
}.to change(::Dorsale::CustomerVault::Individual, :count).by(-1)
|
121
|
+
end
|
122
|
+
|
123
|
+
it "redirects to the individuals list" do
|
124
|
+
individual = ::Dorsale::CustomerVault::Individual.create! valid_attributes
|
125
|
+
delete :destroy, {:id => individual.to_param}, valid_session
|
126
|
+
expect(response).to redirect_to(customer_vault_people_path)
|
127
|
+
end
|
128
|
+
end
|
129
|
+
|
130
|
+
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
require "rails_helper"
|
2
|
+
|
3
|
+
RSpec.describe ::Dorsale::CustomerVault::PeopleController, type: :controller do
|
4
|
+
routes { Dorsale::Engine.routes }
|
5
|
+
|
6
|
+
describe "#index" do
|
7
|
+
it "should redirect to activity" do
|
8
|
+
get :index
|
9
|
+
expect(response).to redirect_to customer_vault_people_activity_path
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
describe '#list' do
|
14
|
+
describe 'sorting' do
|
15
|
+
let!(:alice) {
|
16
|
+
create(:customer_vault_individual, first_name: 'Alice', last_name: 'Zarston')
|
17
|
+
}
|
18
|
+
|
19
|
+
let!(:bob) {
|
20
|
+
create(:customer_vault_individual, first_name: 'Bob', last_name: 'Tilan')
|
21
|
+
}
|
22
|
+
|
23
|
+
let!(:corporation) {
|
24
|
+
create(:customer_vault_corporation, name: 'Zorg Corp')
|
25
|
+
}
|
26
|
+
|
27
|
+
|
28
|
+
it 'should sort people by name by default' do
|
29
|
+
get :list
|
30
|
+
expect(assigns(:people)).to eq([bob, alice, corporation])
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
describe "search" do
|
35
|
+
it "search should ignore filters" do
|
36
|
+
corporation1 = create(:customer_vault_corporation, tag_list: "abc", name: "aaa")
|
37
|
+
corporation2 = create(:customer_vault_corporation, tag_list: "xyz", name: "bbb")
|
38
|
+
@request.cookies["filters"] = {tags: ["abc"]}.to_json
|
39
|
+
get :list, q: "bbb"
|
40
|
+
expect(assigns(:people)).to eq [corporation2]
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
describe "activity" do
|
46
|
+
before do
|
47
|
+
@person = create(:customer_vault_corporation)
|
48
|
+
@comment1 = @person.comments.create!(text: "ABC", created_at: Time.now - 3.days)
|
49
|
+
@comment2 = @person.comments.create!(text: "DEF", created_at: Time.now - 2.days)
|
50
|
+
@comment3 = @person.comments.create!(text: "DEF", created_at: Time.now - 9.days)
|
51
|
+
end
|
52
|
+
|
53
|
+
it "should assigns all comments ordered by created_at DESC" do
|
54
|
+
get :activity
|
55
|
+
expect(assigns(:comments)).to eq [@comment2, @comment1, @comment3]
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
end
|