[Tracker] Add test for duplicated e-mail addresses
authorRaul Gutierrez Segales <raul.gutierrez.segales@collabora.co.uk>
Tue, 5 Apr 2011 13:11:21 +0000 (14:11 +0100)
committerRaul Gutierrez Segales <raul.gutierrez.segales@collabora.co.uk>
Tue, 5 Apr 2011 13:51:47 +0000 (14:51 +0100)
tests/tracker/Makefile.am
tests/tracker/duplicated-emails.vala [new file with mode: 0644]

index fd8a18b..f9b7684 100644 (file)
@@ -90,6 +90,7 @@ noinst_PROGRAMS = \
        set-birthday  \
        set-gender  \
        link-personas  \
+       duplicated-emails  \
        $(NULL)
 
 backend_store_key_file=$(srcdir)/data/backend-tracker-only.ini
@@ -292,6 +293,10 @@ link_personas_SOURCES = \
        link-personas.vala \
        $(NULL)
 
+duplicated_emails_SOURCES = \
+       duplicated-emails.vala \
+       $(NULL)
+
 CLEANFILES = \
         *.pid \
         *.address \
@@ -347,6 +352,7 @@ MAINTAINERCLEANFILES = \
         set_birthday_vala.stamp \
         set_gender_vala.stamp \
         link_personas_vala.stamp \
+        duplicated_emails_vala.stamp \
         $(NULL)
 
 EXTRA_DIST = \
diff --git a/tests/tracker/duplicated-emails.vala b/tests/tracker/duplicated-emails.vala
new file mode 100644 (file)
index 0000000..7ad5e2d
--- /dev/null
@@ -0,0 +1,218 @@
+/*
+ * Copyright (C) 2011 Collabora Ltd.
+ *
+ * This library is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License as published by
+ * the Free Software Foundation, either version 2.1 of the License, or
+ * (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Authors: Raul Gutierrez Segales <raul.gutierrez.segales@collabora.co.uk>
+ *
+ */
+
+using Tracker.Sparql;
+using TrackerTest;
+using Folks;
+using Gee;
+
+public class DuplicatedEmailsTests : Folks.TestCase
+{
+  private GLib.MainLoop _main_loop;
+  private TrackerTest.Backend _tracker_backend;
+  private IndividualAggregator _aggregator;
+  private string _persona_fullname_1 = "persona #1";
+  private string _persona_fullname_2 = "persona #2";
+  private string _email_1 = "some-address@example.org";
+  private bool _added_personas = false;
+  private string _individual_id_1 = "";
+  private string _individual_id_2 = "";
+  private Trf.PersonaStore _pstore;
+
+  public DuplicatedEmailsTests ()
+    {
+      base ("DuplicatedEmailsTests");
+
+      this._tracker_backend = new TrackerTest.Backend ();
+
+      this.add_test ("test adding 2 personas with the same email address ",
+          this.test_duplicated_emails);
+    }
+
+  public override void set_up ()
+    {
+    }
+
+  public override void tear_down ()
+    {
+      this._tracker_backend.tear_down ();
+    }
+
+  public void test_duplicated_emails ()
+    {
+      this._main_loop = new GLib.MainLoop (null, false);
+
+      this._test_duplicated_emails_async ();
+
+      Timeout.add_seconds (5, () =>
+        {
+          this._main_loop.quit ();
+          assert_not_reached ();
+        });
+
+      this._main_loop.run ();
+      assert (this._individual_id_1 != "");
+      assert (this._individual_id_2 != "");
+    }
+
+  private async void _test_duplicated_emails_async ()
+    {
+      var store = BackendStore.dup ();
+      yield store.prepare ();
+      this._aggregator = new IndividualAggregator ();
+      this._aggregator.individuals_changed.connect
+          (this._individuals_changed_cb);
+      try
+        {
+          yield this._aggregator.prepare ();
+          this._pstore = null;
+          foreach (var backend in store.enabled_backends)
+            {
+              this._pstore =
+                (Trf.PersonaStore) backend.persona_stores.lookup ("tracker");
+              if (this._pstore != null)
+                break;
+            }
+          assert (this._pstore != null);
+          this._pstore.notify["is-prepared"].connect (this._notify_pstore_cb);
+          this._try_to_add ();
+        }
+      catch (GLib.Error e)
+        {
+          GLib.warning ("Error when calling prepare: %s\n", e.message);
+        }
+    }
+
+  private void _individuals_changed_cb
+      (GLib.List<Individual>? added,
+       GLib.List<Individual>? removed,
+       string? message,
+       Persona? actor,
+       GroupDetails.ChangeReason reason)
+    {
+      foreach (unowned Individual i in added)
+        {
+          if (i.full_name == this._persona_fullname_1)
+            {
+              this._individual_id_1 = i.id;
+            }
+          else if (i.full_name == this._persona_fullname_2)
+            {
+              this._individual_id_2 = i.id;
+            }
+        }
+
+      if (this._individual_id_1 != "" &&
+          this._individual_id_2 != "")
+        {
+          this._main_loop.quit ();
+        }
+
+      assert (removed == null);
+    }
+
+  private void _notify_pstore_cb (Object _pstore, ParamSpec ps)
+    {
+      this._try_to_add ();
+    }
+
+  private async void _try_to_add ()
+    {
+      lock (this._added_personas)
+        {
+          if (this._pstore.is_prepared &&
+              this._added_personas == false)
+            {
+              this._added_personas = true;
+              yield this._add_personas ();
+            }
+        }
+    }
+
+   /**
+   * Add 2 personas with the same e-mail address. Although
+   * Tracker forbids inserting 2 duplicated nco:EmailAddresses,
+   * our Trf.PersonaStore should be able to detect the existence
+   * of an e-mail address and re-use that instead of trying to
+   * create a new one.
+   */
+  private async void _add_personas ()
+    {
+      HashTable<string, Value?> details1 = new HashTable<string, Value?>
+          (str_hash, str_equal);
+      HashTable<string, Value?> details2 = new HashTable<string, Value?>
+          (str_hash, str_equal);
+      Value? val;
+
+      val = Value (typeof (string));
+      val.set_string (this._persona_fullname_1);
+      details1.insert (Folks.PersonaStore.detail_key (PersonaDetail.FULL_NAME),
+          (owned) val);
+
+      val = Value (typeof (GLib.List<FieldDetails>));
+      var emails1 = new GLib.List<FieldDetails> ();
+      var email_1 = new FieldDetails (this._email_1);
+      emails1.prepend ((owned) email_1);
+      val.set_pointer (emails1);
+      details1.insert (
+          Folks.PersonaStore.detail_key (PersonaDetail.EMAIL_ADDRESSES),
+          (owned) val);
+
+      val = Value (typeof (string));
+      val.set_string (this._persona_fullname_2);
+      details2.insert (Folks.PersonaStore.detail_key (PersonaDetail.FULL_NAME),
+          (owned) val);
+
+      val = Value (typeof (GLib.List<FieldDetails>));
+      var emails2 = new GLib.List<FieldDetails> ();
+      var email_2 = new FieldDetails (this._email_1);
+      emails2.prepend ((owned) email_2);
+      val.set_pointer (emails2);
+      details2.insert (
+          Folks.PersonaStore.detail_key (PersonaDetail.EMAIL_ADDRESSES),
+          (owned) val);
+
+     try
+        {
+          yield this._aggregator.add_persona_from_details (null,
+              this._pstore, details1);
+
+          yield this._aggregator.add_persona_from_details (null,
+              this._pstore, details2);
+        }
+      catch (Folks.IndividualAggregatorError e)
+        {
+          GLib.warning ("[AddPersonaError] add_persona_from_details: %s\n",
+              e.message);
+        }
+    }
+}
+
+public int main (string[] args)
+{
+  Test.init (ref args);
+
+  TestSuite root = TestSuite.get_root ();
+  root.add_suite (new DuplicatedEmailsTests ().get_suite ());
+
+  Test.run ();
+
+  return 0;
+}