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 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/sync/engine_impl/js_sync_manager_observer.h"
#include <vector>
#include "base/location.h"
#include "base/run_loop.h"
#include "base/values.h"
#include "components/sync/base/model_type.h"
#include "components/sync/engine/connection_status.h"
#include "components/sync/engine/cycle/sync_cycle_snapshot.h"
#include "components/sync/engine/sync_string_conversions.h"
#include "components/sync/js/js_event_details.h"
#include "components/sync/js/js_test_util.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace syncer {
namespace {
using ::testing::InSequence;
using ::testing::StrictMock;
class JsSyncManagerObserverTest : public testing::Test {
protected:
JsSyncManagerObserverTest() {
js_sync_manager_observer_.SetJsEventHandler(
mock_js_event_handler_.AsWeakHandle());
}
private:
// This must be destroyed after the member variables below in order
// for WeakHandles to be destroyed properly.
base::MessageLoop message_loop_;
protected:
StrictMock<MockJsEventHandler> mock_js_event_handler_;
JsSyncManagerObserver js_sync_manager_observer_;
void PumpLoop() { base::RunLoop().RunUntilIdle(); }
};
TEST_F(JsSyncManagerObserverTest, OnInitializationComplete) {
base::DictionaryValue expected_details;
ModelTypeSet restored_types;
restored_types.Put(BOOKMARKS);
restored_types.Put(NIGORI);
expected_details.Set("restoredTypes", ModelTypeSetToValue(restored_types));
EXPECT_CALL(mock_js_event_handler_,
HandleJsEvent("onInitializationComplete",
HasDetailsAsDictionary(expected_details)));
js_sync_manager_observer_.OnInitializationComplete(
WeakHandle<JsBackend>(), WeakHandle<DataTypeDebugInfoListener>(), true,
restored_types);
PumpLoop();
}
TEST_F(JsSyncManagerObserverTest, OnSyncCycleCompleted) {
SyncCycleSnapshot snapshot(ModelNeutralState(), ProgressMarkerMap(), false, 5,
2, 7, false, 0, base::Time::Now(),
base::Time::Now(),
std::vector<int>(MODEL_TYPE_COUNT, 0),
std::vector<int>(MODEL_TYPE_COUNT, 0),
sync_pb::GetUpdatesCallerInfo::UNKNOWN);
base::DictionaryValue expected_details;
expected_details.Set("snapshot", snapshot.ToValue());
EXPECT_CALL(mock_js_event_handler_,
HandleJsEvent("onSyncCycleCompleted",
HasDetailsAsDictionary(expected_details)));
js_sync_manager_observer_.OnSyncCycleCompleted(snapshot);
PumpLoop();
}
TEST_F(JsSyncManagerObserverTest, OnActionableError) {
SyncProtocolError sync_error;
sync_error.action = CLEAR_USER_DATA_AND_RESYNC;
sync_error.error_type = TRANSIENT_ERROR;
base::DictionaryValue expected_details;
expected_details.Set("syncError", sync_error.ToValue());
EXPECT_CALL(mock_js_event_handler_,
HandleJsEvent("onActionableError",
HasDetailsAsDictionary(expected_details)));
js_sync_manager_observer_.OnActionableError(sync_error);
PumpLoop();
}
TEST_F(JsSyncManagerObserverTest, OnConnectionStatusChange) {
const ConnectionStatus kStatus = CONNECTION_AUTH_ERROR;
base::DictionaryValue expected_details;
expected_details.SetString("status", ConnectionStatusToString(kStatus));
EXPECT_CALL(mock_js_event_handler_,
HandleJsEvent("onConnectionStatusChange",
HasDetailsAsDictionary(expected_details)));
js_sync_manager_observer_.OnConnectionStatusChange(kStatus);
PumpLoop();
}
} // namespace
} // namespace syncer
|