mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
393bc6639f
- Bug 1209162 - Create OriginAttributes subtypes. IGNORE IDL r=sicking. (c2cbe04ef3) - Bug 1220570 - Potential cookie lost while downgrading from Aurora 44 to 43. r=jduell (1a0111c842) - Bug 1217456: Add a security flag for controlling redirects. Use this flag in fetch() implementation. r=bkelly,jduell (79d449e479) - Bug 1112040 - Add a mochitest. r=bholley (566a05f720) - Bug 1171215 - Compute third-partyness in the loadinfo instead of nsIHttpChannelInternal so that other protocols correctly respect the third-party cookie pref. r=sicking/ckerschb (06f7a10a83) - better backport of Bug 485941 - Stack overflow using overly-deep XML tree (DoS). r=bzbarsky (ac43feeffa) - Bug 1182546 - Use channel->Open2() in parser/htmlparser/nsExpatDriver.cpp (r=bz) (42768f373a) - Bug 1163435 part 1 - [css-grid][css-flexbox] Propagate an explicit CB width/height to the reflow state to resolve percentage lengths for grid items properly. Resolve percent against the size in the same axis for abs.pos. children too. r=dholbert (a55463fb05) - Bug 1163435 part 2 - tests. (bb683c5fc6) - Bug 1223282 - Make NS_AUTOMARGIN be a different value than NS_UNCONSTRAINEDSIZE to avoid having clamped huge margin values be interpreted as auto margins. r=roc (4cdfe0f277) - Bug 1224230 - Explicitly store the lineContainer's writing mode in InlineIntrinsicISizeData. r=dbaron (6474515223) - Bug 1221043. Revert to including trailing whitespace for accessibility APIs. r=marcoz,mats (406018c163) - Bug 1227113 - Fix some indentation issues in ServiceWorkerManager, r=janv (2b343bde09) - Bug 1223116 P1 Expose nsIServiceWorkerManager.shouldReportToWindow(). r=catalinb (02899e429d) - Bug 1226441 - Part 1: Add wpt test verifying fetch event waits for activate to complete; r=catalinb (e8eb3e6e7a) - Bug 1209865 - Add gecko profiler marker when mark() of User Timing API is called. r=baku (f48d76e395) - Bug 1169068 - Performance.translateTime(), r=bz (38cd1c31b2) - Bug 1226441 - Part 2: Delay functional event dispatch until service worker is activated; r=catalinb (778cd3dd24) - Bug 1178233 - [non-e10s] The update process doesn't work within about:serviceworkers in non-e10s mode. Test. r=baku (4f8b6f53f8) - Bug 1188545 - Disable unstable test: test_aboutserviceworkers.html. a=testonly (4bbe106693) - Bug 1219255 - We should be able to attach to a service worker;r=amarchesini (0d6b71b4ec) - Bug 1222464 - Part 2: Implement FetchEvent.clientId; r=jdm (9c8abd62dd) - Bug 1218150 - Mark the members of Clients as NewObject; r=bzbarsky (b6b00a586c) - Bug 1222464 - Part 3: Implement Clients.get(); r=jdm (f5ca60d801) - Bug 1222464 - Part 1: Save a client ID for top-level navigations on the docshell and assign it as the document ID when we start loading the document; r=jdm (7dcb5ce2b6) - Bug 1218141 - Add some SameObject and NewObject annotations to ServiceWorkerGlobalScope; r=bzbarsky (5019f58c7a) - Bug 1218190 - Add a pref to enable Clients.openWindow, r=catalinb (dbb6d007dd) - Bug 1218142 - Remove ServiceWorkerGlobalScope.onbeforeevicted/onevicted; r=bzbarsky (029de6f8ec) - Bug 1218146 - Move WindowClient.frameType to Client.frameType; r=bzbarsky (00f0211276) - Bug 1218147 - Make WindowClient.focus() NewObject; r=bzbarsky (3c6aea4b67) - Bug 1189659 - Part 1 - Continue service worker job queue when life cycle events expire. r=bkelly (aa09cd9c60) - Bug 1227932 - Fix Service Workers SoftUpdate and registration.update code paths. r=ehsan (24567b23c0) - Bug 1189659 - Part 2 - Remove set of scopes being updated from ServiceWorkerManager. r=bkelly (ce581b095c) - Bug 1189659 - Part 3 - Use separate synchronization queues for service worker register jobs and install jobs. r=bkelly (9c408a22ed) - Bug 1189659 - Part 4 - Fix race in test_install_event.html. r=bkelly (3186ffb808) - Bug 1189659 - Part 5 - Fix race in skip-waiting.https.html and add some logging for SkipWaitingFlag in ServiceWorkerManager. r=ehsan (4e5ddda6f3) - Bug 1229056 - Implement ClientQueryOptions.includeUncontrolled; r=jdm (dbe56aa60d) - namespace (3b0863d42d) - Bug 1201127 - Return the same ServiceWorkerRegistration object from service worker APIs dealing with the same underlying registration object; r=jdm (c542688ae0) - Bug 1171583 - Remove mutable warning from |nsSimpleURI::SetUserPass|. r=bz (73934deaad) - Bug 1206199 - Extend channelwrapper to mediate OnStartRequest, OnStopRequest, OnDataAvailable (r=sicking) (758a7ec65c) - Bug 1186783 (part 4) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (681bdba278) - Bug 1186783 (part 3) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (76b8b7191e) - Bug 1186783 (part 2) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (5c0743ac49) - Bug 1186783 (part 1) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (952cc720cc) - Bug 1186783 (part 5) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/ with iterators. r=valentin. (25b9735c52) - Bug 1186783 (part 1) - Replace nsBaseHashtable::EnumerateRead() calls in netwerk/. r=michal. (ae52425809) - Bug 1186783 (follow-up) - Bustage fix for Gonk. (d4a1b769bd) - add back some hotfix stuff, even if unused (fe32076c5b) - Bug 1068087: Switch about:plugins to run remotely. r=mconley (bc4316dd03) - Bug 1214058: Part 1 - Add a simplified JSON-based add-on update protocol. r=Mossop (a3198884d5) - Bug 1214058: Part 2 - Run add-on update tests against comparable JSON and RDF manifests. r=Mossop (aa6a796e6f) - Bug 1152977 - Enable by default DEAA for desktop platforms that use OpenGL compositor. r=jmuizelaar (bfa9efd5c8)
286 lines
9.6 KiB
C++
286 lines
9.6 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "gtest/gtest.h"
|
|
#include "mozilla/BasePrincipal.h"
|
|
#include "mozilla/dom/ServiceWorkerRegistrar.h"
|
|
#include "mozilla/dom/ServiceWorkerRegistrarTypes.h"
|
|
#include "mozilla/ipc/PBackgroundSharedTypes.h"
|
|
|
|
#include "nsAppDirectoryServiceDefs.h"
|
|
#include "nsIFile.h"
|
|
#include "nsIOutputStream.h"
|
|
#include "nsNetUtil.h"
|
|
|
|
using namespace mozilla::dom;
|
|
using namespace mozilla::ipc;
|
|
|
|
class ServiceWorkerRegistrarTest : public ServiceWorkerRegistrar
|
|
{
|
|
public:
|
|
ServiceWorkerRegistrarTest()
|
|
{
|
|
nsresult rv = NS_GetSpecialDirectory(NS_APP_USER_PROFILE_50_DIR,
|
|
getter_AddRefs(mProfileDir));
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
return;
|
|
}
|
|
}
|
|
|
|
nsresult TestReadData() { return ReadData(); }
|
|
nsresult TestWriteData() { return WriteData(); }
|
|
void TestDeleteData() { DeleteData(); }
|
|
|
|
nsTArray<ServiceWorkerRegistrationData>& TestGetData() { return mData; }
|
|
};
|
|
|
|
already_AddRefed<nsIFile>
|
|
GetFile()
|
|
{
|
|
nsCOMPtr<nsIFile> file;
|
|
nsresult rv = NS_GetSpecialDirectory(NS_APP_USER_PROFILE_50_DIR,
|
|
getter_AddRefs(file));
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
return nullptr;
|
|
}
|
|
|
|
file->Append(NS_LITERAL_STRING(SERVICEWORKERREGISTRAR_FILE));
|
|
return file.forget();
|
|
}
|
|
|
|
bool
|
|
CreateFile(const nsACString& aData)
|
|
{
|
|
nsCOMPtr<nsIFile> file = GetFile();
|
|
|
|
nsCOMPtr<nsIOutputStream> stream;
|
|
nsresult rv = NS_NewLocalFileOutputStream(getter_AddRefs(stream), file);
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
return false;
|
|
}
|
|
|
|
uint32_t count;
|
|
rv = stream->Write(aData.Data(), aData.Length(), &count);
|
|
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
return false;
|
|
}
|
|
|
|
if (count != aData.Length()) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestNoFile)
|
|
{
|
|
nsCOMPtr<nsIFile> file = GetFile();
|
|
ASSERT_TRUE(file) << "GetFile must return a nsIFIle";
|
|
|
|
bool exists;
|
|
nsresult rv = file->Exists(&exists);
|
|
ASSERT_EQ(NS_OK, rv) << "nsIFile::Exists cannot fail";
|
|
|
|
if (exists) {
|
|
rv = file->Remove(false);
|
|
ASSERT_EQ(NS_OK, rv) << "nsIFile::Remove cannot fail";
|
|
}
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
rv = swr->TestReadData();
|
|
ASSERT_EQ(NS_OK, rv) << "ReadData() should not fail";
|
|
|
|
const nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
ASSERT_EQ((uint32_t)0, data.Length()) << "No data should be found in an empty file";
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestEmptyFile)
|
|
{
|
|
ASSERT_TRUE(CreateFile(EmptyCString())) << "CreateFile should not fail";
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
nsresult rv = swr->TestReadData();
|
|
ASSERT_NE(NS_OK, rv) << "ReadData() should fail if the file is empty";
|
|
|
|
const nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
ASSERT_EQ((uint32_t)0, data.Length()) << "No data should be found in an empty file";
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestRightVersionFile)
|
|
{
|
|
ASSERT_TRUE(CreateFile(nsAutoCString(SERVICEWORKERREGISTRAR_VERSION "\n"))) << "CreateFile should not fail";
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
nsresult rv = swr->TestReadData();
|
|
ASSERT_EQ(NS_OK, rv) << "ReadData() should not fail when the version is correct";
|
|
|
|
const nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
ASSERT_EQ((uint32_t)0, data.Length()) << "No data should be found in an empty file";
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestWrongVersionFile)
|
|
{
|
|
ASSERT_TRUE(CreateFile(nsAutoCString(SERVICEWORKERREGISTRAR_VERSION "bla\n"))) << "CreateFile should not fail";
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
nsresult rv = swr->TestReadData();
|
|
ASSERT_NE(NS_OK, rv) << "ReadData() should fail when the version is not correct";
|
|
|
|
const nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
ASSERT_EQ((uint32_t)0, data.Length()) << "No data should be found in an empty file";
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestReadData)
|
|
{
|
|
nsAutoCString buffer(SERVICEWORKERREGISTRAR_VERSION "\n");
|
|
|
|
buffer.Append("^appId=123&inBrowser=1\n");
|
|
buffer.Append("spec 0\nscope 0\nscriptSpec 0\ncurrentWorkerURL 0\nactiveCache 0\nwaitingCache 0\n");
|
|
buffer.Append(SERVICEWORKERREGISTRAR_TERMINATOR "\n");
|
|
|
|
buffer.Append("\n");
|
|
buffer.Append("spec 1\nscope 1\nscriptSpec 1\ncurrentWorkerURL 1\nactiveCache 1\nwaitingCache 1\n");
|
|
buffer.Append(SERVICEWORKERREGISTRAR_TERMINATOR "\n");
|
|
|
|
ASSERT_TRUE(CreateFile(buffer)) << "CreateFile should not fail";
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
nsresult rv = swr->TestReadData();
|
|
ASSERT_EQ(NS_OK, rv) << "ReadData() should not fail";
|
|
|
|
const nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
ASSERT_EQ((uint32_t)2, data.Length()) << "4 entries should be found";
|
|
|
|
const mozilla::ipc::PrincipalInfo& info0 = data[0].principal();
|
|
ASSERT_EQ(info0.type(), mozilla::ipc::PrincipalInfo::TContentPrincipalInfo) << "First principal must be content";
|
|
const mozilla::ipc::ContentPrincipalInfo& cInfo0 = data[0].principal();
|
|
|
|
nsAutoCString suffix0;
|
|
cInfo0.attrs().CreateSuffix(suffix0);
|
|
|
|
ASSERT_STREQ("^appId=123&inBrowser=1", suffix0.get());
|
|
ASSERT_STREQ("spec 0", cInfo0.spec().get());
|
|
ASSERT_STREQ("scope 0", data[0].scope().get());
|
|
ASSERT_STREQ("scriptSpec 0", data[0].scriptSpec().get());
|
|
ASSERT_STREQ("currentWorkerURL 0", data[0].currentWorkerURL().get());
|
|
ASSERT_STREQ("activeCache 0", NS_ConvertUTF16toUTF8(data[0].activeCacheName()).get());
|
|
ASSERT_STREQ("waitingCache 0", NS_ConvertUTF16toUTF8(data[0].waitingCacheName()).get());
|
|
|
|
const mozilla::ipc::PrincipalInfo& info1 = data[1].principal();
|
|
ASSERT_EQ(info1.type(), mozilla::ipc::PrincipalInfo::TContentPrincipalInfo) << "First principal must be content";
|
|
const mozilla::ipc::ContentPrincipalInfo& cInfo1 = data[1].principal();
|
|
|
|
nsAutoCString suffix1;
|
|
cInfo1.attrs().CreateSuffix(suffix1);
|
|
|
|
ASSERT_STREQ("", suffix1.get());
|
|
ASSERT_STREQ("spec 1", cInfo1.spec().get());
|
|
ASSERT_STREQ("scope 1", data[1].scope().get());
|
|
ASSERT_STREQ("scriptSpec 1", data[1].scriptSpec().get());
|
|
ASSERT_STREQ("currentWorkerURL 1", data[1].currentWorkerURL().get());
|
|
ASSERT_STREQ("activeCache 1", NS_ConvertUTF16toUTF8(data[1].activeCacheName()).get());
|
|
ASSERT_STREQ("waitingCache 1", NS_ConvertUTF16toUTF8(data[1].waitingCacheName()).get());
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestDeleteData)
|
|
{
|
|
ASSERT_TRUE(CreateFile(nsAutoCString("Foobar"))) << "CreateFile should not fail";
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
swr->TestDeleteData();
|
|
|
|
nsCOMPtr<nsIFile> file = GetFile();
|
|
|
|
bool exists;
|
|
nsresult rv = file->Exists(&exists);
|
|
ASSERT_EQ(NS_OK, rv) << "nsIFile::Exists cannot fail";
|
|
|
|
ASSERT_FALSE(exists) << "The file should not exist after a DeleteData().";
|
|
}
|
|
|
|
TEST(ServiceWorkerRegistrar, TestWriteData)
|
|
{
|
|
{
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
|
|
for (int i = 0; i < 10; ++i) {
|
|
ServiceWorkerRegistrationData* d = data.AppendElement();
|
|
|
|
nsAutoCString spec;
|
|
spec.AppendPrintf("spec write %d", i);
|
|
d->principal() = mozilla::ipc::ContentPrincipalInfo(mozilla::PrincipalOriginAttributes(i, i % 2), spec);
|
|
d->scope().AppendPrintf("scope write %d", i);
|
|
d->scriptSpec().AppendPrintf("scriptSpec write %d", i);
|
|
d->currentWorkerURL().AppendPrintf("currentWorkerURL write %d", i);
|
|
d->activeCacheName().AppendPrintf("activeCacheName write %d", i);
|
|
d->waitingCacheName().AppendPrintf("waitingCacheName write %d", i);
|
|
}
|
|
|
|
nsresult rv = swr->TestWriteData();
|
|
ASSERT_EQ(NS_OK, rv) << "WriteData() should not fail";
|
|
}
|
|
|
|
RefPtr<ServiceWorkerRegistrarTest> swr = new ServiceWorkerRegistrarTest;
|
|
|
|
nsresult rv = swr->TestReadData();
|
|
ASSERT_EQ(NS_OK, rv) << "ReadData() should not fail";
|
|
|
|
const nsTArray<ServiceWorkerRegistrationData>& data = swr->TestGetData();
|
|
ASSERT_EQ((uint32_t)10, data.Length()) << "10 entries should be found";
|
|
|
|
for (int i = 0; i < 10; ++i) {
|
|
nsAutoCString test;
|
|
|
|
ASSERT_EQ(data[i].principal().type(), mozilla::ipc::PrincipalInfo::TContentPrincipalInfo);
|
|
const mozilla::ipc::ContentPrincipalInfo& cInfo = data[i].principal();
|
|
|
|
mozilla::PrincipalOriginAttributes attrs(i, i % 2);
|
|
nsAutoCString suffix, expectSuffix;
|
|
attrs.CreateSuffix(expectSuffix);
|
|
cInfo.attrs().CreateSuffix(suffix);
|
|
|
|
ASSERT_STREQ(expectSuffix.get(), suffix.get());
|
|
|
|
test.AppendPrintf("spec write %d", i);
|
|
ASSERT_STREQ(test.get(), cInfo.spec().get());
|
|
|
|
test.Truncate();
|
|
test.AppendPrintf("scope write %d", i);
|
|
ASSERT_STREQ(test.get(), data[i].scope().get());
|
|
|
|
test.Truncate();
|
|
test.AppendPrintf("scriptSpec write %d", i);
|
|
ASSERT_STREQ(test.get(), data[i].scriptSpec().get());
|
|
|
|
test.Truncate();
|
|
test.AppendPrintf("currentWorkerURL write %d", i);
|
|
ASSERT_STREQ(test.get(), data[i].currentWorkerURL().get());
|
|
|
|
test.Truncate();
|
|
test.AppendPrintf("activeCacheName write %d", i);
|
|
ASSERT_STREQ(test.get(), NS_ConvertUTF16toUTF8(data[i].activeCacheName()).get());
|
|
|
|
test.Truncate();
|
|
test.AppendPrintf("waitingCacheName write %d", i);
|
|
ASSERT_STREQ(test.get(), NS_ConvertUTF16toUTF8(data[i].waitingCacheName()).get());
|
|
}
|
|
}
|
|
|
|
int main(int argc, char** argv) {
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
int rv = RUN_ALL_TESTS();
|
|
return rv;
|
|
}
|