INFRA-132 - Misc js
authorTim Otten <totten@civicrm.org>
Tue, 27 Jan 2015 05:53:48 +0000 (21:53 -0800)
committerTim Otten <totten@civicrm.org>
Tue, 27 Jan 2015 05:53:48 +0000 (21:53 -0800)
templates/CRM/Core/BillingBlock.js
templates/CRM/common/TabHeader.js
tests/qunit/crm-backbone/test.js

index abe4376dfd79d2366cd63862c87ebb484cc20a57..dec4b6581fc3a1ebbfd3b889ca95d7ef004b5ffe 100644 (file)
@@ -51,7 +51,7 @@
       'discover': '6011[0-9]{12}',
       'jcb': '(?:3[0-9]{15}|(2131|1800)[0-9]{11})',
       'unionpay': '62(?:[0-9]{14}|[0-9]{17})'
-    }
+    };
 
     var card_values = {
       'mastercard': 'MasterCard',
@@ -62,7 +62,7 @@
       'discover': 'Discover',
       'jcb': 'JCB',
       'unionpay': 'UnionPay'
-    }
+    };
 
     $.each(card_types, function(key, pattern) {
       if (ccnumber.match('^' + pattern + '$')) {
index 9433900c20df626e16eeb1bbe5c8994b1ca8be3c..e816f0baacd46b33bf5416e39fe6661d2a29a22a 100644 (file)
@@ -25,7 +25,7 @@ CRM.$(function($) {
             // Hack: "Save and done" and "Cancel" buttons submit without ajax
             $('.cancel.crm-form-submit, input[name$=upload_done]', this).on('click', function(e) {
               $(this).closest('form').ajaxFormUnbind();
-            })
+            });
           });
         }
         if (ui.tab.hasClass('livePage') && CRM.config.ajaxPopupsEnabled) {
index cdf242f7636854693567ea6c0fd3b7118ddb2176..614d4b25f2b41367be87a46ad46f7eccafd489fb 100644 (file)
-/* ------------ Fixtures/constants ------------ */
-
-var VALID_CONTACT_ID = 3;
-var MALFORMED_CONTACT_ID = 'z';
-
-var ContactModel = Backbone.Model.extend({});
-CRM.Backbone.extendModel(ContactModel, 'Contact');
-CRM.Backbone.trackSaved(ContactModel);
-
-var ContactCollection = Backbone.Collection.extend({
-  model: ContactModel
-});
-CRM.Backbone.extendCollection(ContactCollection);
-
-/* ------------ Assertions ------------ */
-
-/**
- * Assert "result" contains an API error
- * @param result
- */
-function assertApiError(result) {
-  equal(1, result.is_error, 'Expected error boolean');
-  ok(result.error_message.length > 0, 'Expected error message')
-}
-
-/**
- * When calling an AJAX operation which should return successfully,
- * make sure that there's no error by setting a callback (error: onUnexpectedError)
- */
-function onUnexpectedError(ignore, result) {
-  if (result && result.error_message) {
-    ok(false, "API returned an unexpected error: " + result.error_message);
-  } else {
-    ok(false, "API returned an unexpected error: (missing message)");
-  }
-  start();
-}
-
-/**
- * When calling an AJAX operation which should return an error,
- * make sure that there's no success by setting a callback (success: onUnexpectedSuccess)
- */
-function onUnexpectedSuccess(ignore) {
-  ok(false, "API succeeded - but failure was expected");
-  start();
-}
-
-/* ------------ Test cases ------------ */
-
-module('model - read');
-
-asyncTest("fetch (ok)", function() {
-  var c = new ContactModel({id: VALID_CONTACT_ID});
-  c.fetch({
-    error: onUnexpectedError,
-    success: function() {
-      notEqual(-1, _.indexOf(['Individual', 'Household', 'Organization'], c.get('contact_type')), 'Loaded contact with valid contact_type');
-      ok(c.get('display_name') != '', 'Loaded contact with valid name');
-      start();
-    }
-  });
-});
-
-asyncTest("fetch (error)", function() {
-  var c = new ContactModel({id: MALFORMED_CONTACT_ID});
-  c.fetch({
-    success: onUnexpectedSuccess,
-    error: function(model, error) {
-      assertApiError(error);
-      start();
-    }
-  });
-});
+(function(CRM,_){
+  /* ------------ Fixtures/constants ------------ */
 
-module('model - create');
+  var VALID_CONTACT_ID = 3;
+  var MALFORMED_CONTACT_ID = 'z';
 
-asyncTest("create/read/delete/read (ok)", function() {
-  var TOKEN = new Date().getTime();
-  var c1 = new ContactModel({
-    contact_type: "Individual",
-    first_name: "George" + TOKEN,
-    last_name: "Anon" + TOKEN
-  });
-  equal(c1.isSaved(), false, "");
-
-  // Create the new contact
-  c1.save({}, {
-    error: onUnexpectedError,
-    success: function() {
-      equal(c1.get("first_name"), "George" + TOKEN, "save() should return new first name");
-      equal(c1.isSaved(), true, "");
-
-      // Fetch the newly created contact
-      var c2 = new ContactModel({id: c1.get('id')});
-      equal(c2.isSaved(), true, "");
-      c2.fetch({
-        error: onUnexpectedError,
-        success: function() {
-          equal(c2.get("first_name"), c1.get("first_name"), "fetch() should return first name");
-          equal(c2.isSaved(), true, "");
-
-          // Destroy the newly created contact
-          c2.destroy({
-            error: onUnexpectedError,
-            success: function() {
-              equal(c2.isSaved(), true, "");
-
-              // Attempt (but fail) to fetch the deleted contact
-              var c3 = new ContactModel({id: c1.get('id')});
-              equal(c3.isSaved(), true, "");
-              c3.fetch({
-                success: onUnexpectedSuccess,
-                error: function(model, error) {
-                  assertApiError(error);
-                  start();
-                }
-              }); // fetch
-            }
-          }); // destroy
-        }
-      }); // fetch
-    }
-  }); // save
-});
-
-asyncTest("create (error)", function() {
-  var TOKEN = new Date().getTime();
-  var c1 = new ContactModel({
-    // MISSING: contact_type: "Individual",
-    first_name: "George" + TOKEN,
-    last_name: "Anon" + TOKEN
+  var ContactModel = Backbone.Model.extend({});
+  CRM.Backbone.extendModel(ContactModel, 'Contact');
+  CRM.Backbone.trackSaved(ContactModel);
+
+  var ContactCollection = Backbone.Collection.extend({
+    model: ContactModel
   });
+  CRM.Backbone.extendCollection(ContactCollection);
+
+  /* ------------ Assertions ------------ */
 
-  // Create the new contact
-  c1.save({}, {
-    success: onUnexpectedSuccess,
-    error: function(model, error) {
-      assertApiError(error);
-      start();
+  /**
+   * Assert "result" contains an API error
+   * @param result
+   */
+  function assertApiError(result) {
+    equal(1, result.is_error, 'Expected error boolean');
+    ok(result.error_message.length > 0, 'Expected error message');
+  }
+
+  /**
+   * When calling an AJAX operation which should return successfully,
+   * make sure that there's no error by setting a callback (error: onUnexpectedError)
+   */
+  function onUnexpectedError(ignore, result) {
+    if (result && result.error_message) {
+      ok(false, "API returned an unexpected error: " + result.error_message);
+    } else {
+      ok(false, "API returned an unexpected error: (missing message)");
     }
-  });
-});
+    start();
+  }
+
+  /**
+   * When calling an AJAX operation which should return an error,
+   * make sure that there's no success by setting a callback (success: onUnexpectedSuccess)
+   */
+  function onUnexpectedSuccess(ignore) {
+    ok(false, "API succeeded - but failure was expected");
+    start();
+  }
 
-module('model - update');
+  /* ------------ Test cases ------------ */
 
-asyncTest("update (ok)", function() {
-  var NICKNAME = "George" + new Date().getTime();
-  var c = new ContactModel({id: VALID_CONTACT_ID});
-  equal(c.isSaved(), true, "");
-  c.set({
-    nick_name: NICKNAME
+  module('model - read');
+
+  asyncTest("fetch (ok)", function() {
+    var c = new ContactModel({id: VALID_CONTACT_ID});
+    c.fetch({
+      error: onUnexpectedError,
+      success: function() {
+        notEqual(-1, _.indexOf(['Individual', 'Household', 'Organization'], c.get('contact_type')), 'Loaded contact with valid contact_type');
+        ok(c.get('display_name') !== '', 'Loaded contact with valid name');
+        start();
+      }
+    });
   });
-  equal(c.isSaved(), false, "");
-  c.save({}, {
-    error: onUnexpectedError,
-    success: function() {
-      equal(c.get("nick_name"), NICKNAME, "save() should return new nickname");
-      _.defer(function(){
-        equal(c.isSaved(), true, "");
-
-        // read back - make sure the save worked
-        var c2 = new ContactModel({id: VALID_CONTACT_ID});
+
+  asyncTest("fetch (error)", function() {
+    var c = new ContactModel({id: MALFORMED_CONTACT_ID});
+    c.fetch({
+      success: onUnexpectedSuccess,
+      error: function(model, error) {
+        assertApiError(error);
+        start();
+      }
+    });
+  });
+
+  module('model - create');
+
+  asyncTest("create/read/delete/read (ok)", function() {
+    var TOKEN = new Date().getTime();
+    var c1 = new ContactModel({
+      contact_type: "Individual",
+      first_name: "George" + TOKEN,
+      last_name: "Anon" + TOKEN
+    });
+    equal(c1.isSaved(), false, "");
+
+    // Create the new contact
+    c1.save({}, {
+      error: onUnexpectedError,
+      success: function() {
+        equal(c1.get("first_name"), "George" + TOKEN, "save() should return new first name");
+        equal(c1.isSaved(), true, "");
+
+        // Fetch the newly created contact
+        var c2 = new ContactModel({id: c1.get('id')});
+        equal(c2.isSaved(), true, "");
         c2.fetch({
           error: onUnexpectedError,
           success: function() {
-            equal(c2.get("nick_name"), NICKNAME, "fetch() should return new nickname");
-            start();
+            equal(c2.get("first_name"), c1.get("first_name"), "fetch() should return first name");
+            equal(c2.isSaved(), true, "");
+
+            // Destroy the newly created contact
+            c2.destroy({
+              error: onUnexpectedError,
+              success: function() {
+                equal(c2.isSaved(), true, "");
+
+                // Attempt (but fail) to fetch the deleted contact
+                var c3 = new ContactModel({id: c1.get('id')});
+                equal(c3.isSaved(), true, "");
+                c3.fetch({
+                  success: onUnexpectedSuccess,
+                  error: function(model, error) {
+                    assertApiError(error);
+                    start();
+                  }
+                }); // fetch
+              }
+            }); // destroy
           }
-        });
-      });
-    }
-  });
-});
-
-asyncTest("update (error)", function() {
-  var NICKNAME = "George" + new Date().getTime();
-  var c = new ContactModel({id: VALID_CONTACT_ID});
-  equal(c.isSaved(), true, "");
-  c.set({
-    contact_type: 'Not-a.va+lidConta(ype'
+        }); // fetch
+      }
+    }); // save
   });
-  equal(c.isSaved(), false, "");
-  c.save({}, {
-    success: onUnexpectedSuccess,
-    error: function(model, error) {
-      assertApiError(error);
-      _.defer(function(){
-        equal(c.isSaved(), false, "");
+
+  asyncTest("create (error)", function() {
+    var TOKEN = new Date().getTime();
+    var c1 = new ContactModel({
+      // MISSING: contact_type: "Individual",
+      first_name: "George" + TOKEN,
+      last_name: "Anon" + TOKEN
+    });
+
+    // Create the new contact
+    c1.save({}, {
+      success: onUnexpectedSuccess,
+      error: function(model, error) {
+        assertApiError(error);
         start();
-      });
-    }
+      }
+    });
   });
-});
-
 
-module('collection - read');
-
-asyncTest("fetch by contact_type (passive criteria, 1+ results)", function() {
-  var c = new ContactCollection([], {
-    crmCriteria: {
-      contact_type: 'Organization'
-    }
-  });
-  c.fetch({
-    error: onUnexpectedError,
-    success: function() {
-      ok(c.models.length > 0, "Expected at least one contact");
-      c.each(function(model) {
-        equal(model.get('contact_type'), 'Organization', 'Expected contact with type organization');
-        ok(model.get('display_name') != '', 'Expected contact with valid name');
-      });
-      start();
-    }
+  module('model - update');
+
+  asyncTest("update (ok)", function() {
+    var NICKNAME = "George" + new Date().getTime();
+    var c = new ContactModel({id: VALID_CONTACT_ID});
+    equal(c.isSaved(), true, "");
+    c.set({
+      nick_name: NICKNAME
+    });
+    equal(c.isSaved(), false, "");
+    c.save({}, {
+      error: onUnexpectedError,
+      success: function() {
+        equal(c.get("nick_name"), NICKNAME, "save() should return new nickname");
+        _.defer(function(){
+          equal(c.isSaved(), true, "");
+
+          // read back - make sure the save worked
+          var c2 = new ContactModel({id: VALID_CONTACT_ID});
+          c2.fetch({
+            error: onUnexpectedError,
+            success: function() {
+              equal(c2.get("nick_name"), NICKNAME, "fetch() should return new nickname");
+              start();
+            }
+          });
+        });
+      }
+    });
   });
-});
 
-asyncTest("fetch by contact_type (active criteria, 1+ results)", function() {
-  var criteria = new Backbone.Model({
-    contact_type: 'Organization'
-  });
-  var c = new ContactCollection([], {
-    crmCriteriaModel: criteria
-  });
-  c.fetch({
-    error: onUnexpectedError,
-    success: function() {
-      ok(c.models.length > 0, "Expected at least one contact");
-      c.each(function(model) {
-        equal(model.get('contact_type'), 'Organization', 'Expected contact with type organization');
-        ok(model.get('display_name') != '', 'Expected contact with valid name');
-      });
-      start();
-    }
+  asyncTest("update (error)", function() {
+    var NICKNAME = "George" + new Date().getTime();
+    var c = new ContactModel({id: VALID_CONTACT_ID});
+    equal(c.isSaved(), true, "");
+    c.set({
+      contact_type: 'Not-a.va+lidConta(ype'
+    });
+    equal(c.isSaved(), false, "");
+    c.save({}, {
+      success: onUnexpectedSuccess,
+      error: function(model, error) {
+        assertApiError(error);
+        _.defer(function(){
+          equal(c.isSaved(), false, "");
+          start();
+        });
+      }
+    });
   });
-});
 
-asyncTest("fetch by contact_type (active criteria revision, 1+ results)", function() {
-  var criteria = new Backbone.Model({
-    contact_type: 'Household'
-  });
-  var c = new ContactCollection([], {
-    crmCriteriaModel: criteria
-  });
-  c.fetch({
-    error: onUnexpectedError,
-    success: function() {
-      ok(c.models.length > 0, "Expected at least one contact");
-      c.each(function(model) {
-        equal(model.get('contact_type'), 'Household', 'Expected contact with type household');
-        ok(model.get('display_name') != '', 'Expected contact with valid name');
-      });
-
-      criteria.set('contact_type', 'Organization');
-      _.delay(function() {
+
+  module('collection - read');
+
+  asyncTest("fetch by contact_type (passive criteria, 1+ results)", function() {
+    var c = new ContactCollection([], {
+      crmCriteria: {
+        contact_type: 'Organization'
+      }
+    });
+    c.fetch({
+      error: onUnexpectedError,
+      success: function() {
         ok(c.models.length > 0, "Expected at least one contact");
         c.each(function(model) {
           equal(model.get('contact_type'), 'Organization', 'Expected contact with type organization');
-          ok(model.get('display_name') != '', 'Expected contact with valid name');
+          ok(model.get('display_name') !== '', 'Expected contact with valid name');
         });
         start();
-      }, 1000);
-    }
+      }
+    });
   });
-});
 
-asyncTest("fetch by crazy name (0 results)", function() {
-  var c = new ContactCollection([], {
-    crmCriteria: {
-      display_name: 'asdf23vmlk2309lk2lkasdk-23ASDF32f'
-    }
+  asyncTest("fetch by contact_type (active criteria, 1+ results)", function() {
+    var criteria = new Backbone.Model({
+      contact_type: 'Organization'
+    });
+    var c = new ContactCollection([], {
+      crmCriteriaModel: criteria
+    });
+    c.fetch({
+      error: onUnexpectedError,
+      success: function() {
+        ok(c.models.length > 0, "Expected at least one contact");
+        c.each(function(model) {
+          equal(model.get('contact_type'), 'Organization', 'Expected contact with type organization');
+          ok(model.get('display_name') !== '', 'Expected contact with valid name');
+        });
+        start();
+      }
+    });
   });
-  c.fetch({
-    error: onUnexpectedError,
-    success: function() {
-      equal(c.models.length, 0, "Expected no contacts");
-      start();
-    }
+
+  asyncTest("fetch by contact_type (active criteria revision, 1+ results)", function() {
+    var criteria = new Backbone.Model({
+      contact_type: 'Household'
+    });
+    var c = new ContactCollection([], {
+      crmCriteriaModel: criteria
+    });
+    c.fetch({
+      error: onUnexpectedError,
+      success: function() {
+        ok(c.models.length > 0, "Expected at least one contact");
+        c.each(function(model) {
+          equal(model.get('contact_type'), 'Household', 'Expected contact with type household');
+          ok(model.get('display_name') !== '', 'Expected contact with valid name');
+        });
+
+        criteria.set('contact_type', 'Organization');
+        _.delay(function() {
+          ok(c.models.length > 0, "Expected at least one contact");
+          c.each(function(model) {
+            equal(model.get('contact_type'), 'Organization', 'Expected contact with type organization');
+            ok(model.get('display_name') !== '', 'Expected contact with valid name');
+          });
+          start();
+        }, 1000);
+      }
+    });
   });
-});
 
-asyncTest("fetch by malformed ID (error)", function() {
-  var c = new ContactCollection([], {
-    crmCriteria: {
-      id: MALFORMED_CONTACT_ID
-    }
+  asyncTest("fetch by crazy name (0 results)", function() {
+    var c = new ContactCollection([], {
+      crmCriteria: {
+        display_name: 'asdf23vmlk2309lk2lkasdk-23ASDF32f'
+      }
+    });
+    c.fetch({
+      error: onUnexpectedError,
+      success: function() {
+        equal(c.models.length, 0, "Expected no contacts");
+        start();
+      }
+    });
   });
-  c.fetch({
-    success: onUnexpectedSuccess,
-    error: function(collection, error) {
-      assertApiError(error);
-      start();
-    }
+
+  asyncTest("fetch by malformed ID (error)", function() {
+    var c = new ContactCollection([], {
+      crmCriteria: {
+        id: MALFORMED_CONTACT_ID
+      }
+    });
+    c.fetch({
+      success: onUnexpectedSuccess,
+      error: function(collection, error) {
+        assertApiError(error);
+        start();
+      }
+    });
   });
-});
-
-module('findCreate');
-
-asyncTest("findCreate by ID (1 result)", function() {
-  CRM.Backbone.findCreate({
-    CollectionClass: ContactCollection,
-    crmCriteria: {
-      id: VALID_CONTACT_ID
-    },
-    error: onUnexpectedError,
-    success: function(model) {
-      equal(model.get('id'), VALID_CONTACT_ID);
-      ok(model.get('contact_type') != '', 'Expected contact with valid type')
-      ok(model.get('id'), 'Expected contact with valid ID')
-      start();
-    }
+
+  module('findCreate');
+
+  asyncTest("findCreate by ID (1 result)", function() {
+    CRM.Backbone.findCreate({
+      CollectionClass: ContactCollection,
+      crmCriteria: {
+        id: VALID_CONTACT_ID
+      },
+      error: onUnexpectedError,
+      success: function(model) {
+        equal(model.get('id'), VALID_CONTACT_ID);
+        ok(model.get('contact_type') !== '', 'Expected contact with valid type');
+        ok(model.get('id'), 'Expected contact with valid ID');
+        start();
+      }
+    });
   });
-});
-
-asyncTest("findCreate by crazy name (0 results) - autocreate", function() {
-  CRM.Backbone.findCreate({
-    CollectionClass: ContactCollection,
-    crmCriteria: {
-      organization_name: 'asdf23vmlk2309lk2lkasdk-23ASDF32f'
-    },
-    defaults: {
-      contact_type: 'Organization'
-    },
-    error: onUnexpectedError,
-    success: function(model) {
-      equal(model.get('organization_name'), 'asdf23vmlk2309lk2lkasdk-23ASDF32f', 'Expected default values from crmCriteria');
-      equal(model.get('contact_type'), 'Organization', 'Expected default values from parameters');
-      ok(!model.get('id'), 'Expected contact without valid ID')
-      start();
-    }
+
+  asyncTest("findCreate by crazy name (0 results) - autocreate", function() {
+    CRM.Backbone.findCreate({
+      CollectionClass: ContactCollection,
+      crmCriteria: {
+        organization_name: 'asdf23vmlk2309lk2lkasdk-23ASDF32f'
+      },
+      defaults: {
+        contact_type: 'Organization'
+      },
+      error: onUnexpectedError,
+      success: function(model) {
+        equal(model.get('organization_name'), 'asdf23vmlk2309lk2lkasdk-23ASDF32f', 'Expected default values from crmCriteria');
+        equal(model.get('contact_type'), 'Organization', 'Expected default values from parameters');
+        ok(!model.get('id'), 'Expected contact without valid ID');
+        start();
+      }
+    });
   });
-});
-
-asyncTest("findCreate by malformed ID (error)", function() {
-  CRM.Backbone.findCreate({
-    CollectionClass: ContactCollection,
-    crmCriteria: {
-      id: MALFORMED_CONTACT_ID
-    },
-    success: onUnexpectedSuccess,
-    error: function(collection, error) {
-      assertApiError(error);
-      start();
-    }
+
+  asyncTest("findCreate by malformed ID (error)", function() {
+    CRM.Backbone.findCreate({
+      CollectionClass: ContactCollection,
+      crmCriteria: {
+        id: MALFORMED_CONTACT_ID
+      },
+      success: onUnexpectedSuccess,
+      error: function(collection, error) {
+        assertApiError(error);
+        start();
+      }
+    });
   });
-});
+
+})(CRM,CRM._);
\ No newline at end of file