summaryrefslogtreecommitdiffstats
path: root/comm/mailnews/local/test/unit/test_pop3Password3.js
blob: b12181e7467f2b7dd639d5ca914687e792aa42b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/**
 * Extra tests for POP3 passwords (forgetPassword)
 */

/* import-globals-from ../../../test/resources/passwordStorage.js */
load("../../../resources/passwordStorage.js");

var kUser1 = "testpop3";
var kUser2 = "testpop3a";
var kProtocol = "pop3";
var kHostname = "localhost";
var kServerUrl = "mailbox://" + kHostname;

add_task(async function () {
  // Prepare files for passwords (generated by a script in bug 1018624).
  await setupForPassword("signons-mailnews1.8-multiple.json");

  // Set up the basic accounts and folders.
  // We would use createPop3ServerAndLocalFolders() however we want to have
  // a different username and NO password for this test (as we expect to load
  // it from the signons json file in which the login information is stored).
  localAccountUtils.loadLocalMailAccount();

  let incomingServer1 = MailServices.accounts.createIncomingServer(
    kUser1,
    kHostname,
    kProtocol
  );

  let incomingServer2 = MailServices.accounts.createIncomingServer(
    kUser2,
    kHostname,
    kProtocol
  );

  // Test - Check there are two logins to begin with.
  var logins = Services.logins.findLogins(kServerUrl, null, kServerUrl);

  Assert.equal(logins.length, 2);

  // These will either be one way around or the other.
  if (logins[0].username == kUser1) {
    Assert.equal(logins[1].username, kUser2);
  } else {
    Assert.equal(logins[0].username, kUser2);
    Assert.equal(logins[1].username, kUser1);
  }

  // Test - Remove a login via the incoming server
  incomingServer1.forgetPassword();

  logins = Services.logins.findLogins(kServerUrl, null, kServerUrl);

  // should be one login left for kUser2
  Assert.equal(logins.length, 1);
  Assert.equal(logins[0].username, kUser2);

  // Bug 561056 - Expand username to also contain domain (i.e. full email).
  incomingServer2.username = kUser2 + "@local.host";

  logins = Services.logins.findLogins(kServerUrl, null, kServerUrl);

  // There should still be the one login left for kUser2
  Assert.equal(logins.length, 1);
  // LoginInfo should be migrated in MsgIncomingServer.jsm.
  Assert.equal(logins[0].username, incomingServer2.username);

  // Change username to another one.
  incomingServer2.username = "testpop";
  logins = Services.logins.findLogins(kServerUrl, null, kServerUrl);

  // LoginInfo should be migrated in MsgIncomingServer.jsm.
  Assert.equal(logins.length, 1);
});