define(['jquery', 'js/models/xblock_validation', 'js/views/xblock_validation', 'common/js/spec_helpers/template_helpers'],
    function($, XBlockValidationModel, XBlockValidationView, TemplateHelpers) {
        beforeEach(function() {
            TemplateHelpers.installTemplate('xblock-validation-messages');
        });

        describe('XBlockValidationView helper methods', function() {
            var model, view;

            beforeEach(function() {
                model = new XBlockValidationModel({parse: true});
                view = new XBlockValidationView({model: model});
                view.render();
            });

            it('has a getIcon method', function() {
                var getIcon = view.getIcon.bind(view);

                expect(getIcon(model.WARNING)).toBe('fa-exclamation-triangle');
                expect(getIcon(model.NOT_CONFIGURED)).toBe('fa-exclamation-triangle');
                expect(getIcon(model.ERROR)).toBe('fa-exclamation-circle');
                expect(getIcon('unknown')).toBeNull();
            });

            it('has a getDisplayName method', function() {
                var getDisplayName = view.getDisplayName.bind(view);

                expect(getDisplayName(model.WARNING)).toBe('Warning');
                expect(getDisplayName(model.NOT_CONFIGURED)).toBe('Warning');
                expect(getDisplayName(model.ERROR)).toBe('Error');
                expect(getDisplayName('unknown')).toBeNull();
            });

            it('can add additional classes', function() {
                var noContainerContent = 'no-container-content',
                    notConfiguredModel, nonRootView, rootView;

                expect(view.getAdditionalClasses()).toBe('');
                expect(view.$('.validation')).not.toHaveClass(noContainerContent);

                notConfiguredModel = new XBlockValidationModel({
                    empty: false, summary: {text: 'Not configured', type: model.NOT_CONFIGURED},
                    xblock_id: 'id'
                },
                    {parse: true}
                );
                nonRootView = new XBlockValidationView({model: notConfiguredModel});
                nonRootView.render();
                expect(nonRootView.getAdditionalClasses()).toBe('');
                expect(view.$('.validation')).not.toHaveClass(noContainerContent);

                rootView = new XBlockValidationView({model: notConfiguredModel, root: true});
                rootView.render();
                expect(rootView.getAdditionalClasses()).toBe(noContainerContent);
                expect(rootView.$('.validation')).toHaveClass(noContainerContent);
            });
        });

        describe('XBlockValidationView rendering', function() {
            var model, view;

            beforeEach(function() {
                model = new XBlockValidationModel({
                    empty: false,
                    summary: {
                        text: 'Summary message', type: 'error',
                        action_label: 'Summary Action', action_class: 'edit-button'
                    },
                    messages: [
                        {
                            text: 'First message', type: 'warning',
                            action_label: 'First Message Action', action_runtime_event: 'fix-up'
                        },
                         {text: 'Second message', type: 'error'}
                    ],
                    xblock_id: 'id'
                });
                view = new XBlockValidationView({model: model});
                view.render();
            });

            it('renders summary and detailed messages types', function() {
                var details;

                expect(view.$('.xblock-message')).toHaveClass('has-errors');
                details = view.$('.xblock-message-item');
                expect(details.length).toBe(2);
                expect(details[0]).toHaveClass('warning');
                expect(details[1]).toHaveClass('error');
            });

            it('renders summary and detailed messages text', function() {
                var details;

                expect(view.$('.xblock-message').text()).toContain('Summary message');

                details = view.$('.xblock-message-item');
                expect(details.length).toBe(2);
                expect($(details[0]).text()).toContain('Warning');
                expect($(details[0]).text()).toContain('First message');
                expect($(details[1]).text()).toContain('Error');
                expect($(details[1]).text()).toContain('Second message');
            });

            it('renders action info', function() {
                expect(view.$('a.edit-button .action-button-text').text()).toContain('Summary Action');

                expect(view.$('a.notification-action-button .action-button-text').text()).
                    toContain('First Message Action');
                expect(view.$('a.notification-action-button').data('notification-action')).toBe('fix-up');
            });

            it('renders a summary only', function() {
                var summaryOnlyModel = new XBlockValidationModel({
                        empty: false,
                        summary: {text: 'Summary message', type: 'warning'},
                        xblock_id: 'id'
                    }),
                    summaryOnlyView, details;

                summaryOnlyView = new XBlockValidationView({model: summaryOnlyModel});
                summaryOnlyView.render();

                expect(summaryOnlyView.$('.xblock-message')).toHaveClass('has-warnings');
                expect(view.$('.xblock-message').text()).toContain('Summary message');

                details = summaryOnlyView.$('.xblock-message-item');
                expect(details.length).toBe(0);
            });
        });
    }
);