Home | History | Annotate | Download | only in performance
      1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #include "base/strings/string_number_conversions.h"
      6 #include "chrome/browser/sync/profile_sync_service_harness.h"
      7 #include "chrome/browser/sync/test/integration/dictionary_helper.h"
      8 #include "chrome/browser/sync/test/integration/performance/sync_timing_helper.h"
      9 #include "chrome/browser/sync/test/integration/sync_test.h"
     10 #include "chrome/common/spellcheck_common.h"
     11 
     12 class DictionarySyncPerfTest : public SyncTest {
     13  public:
     14   DictionarySyncPerfTest() : SyncTest(TWO_CLIENT) {}
     15   virtual ~DictionarySyncPerfTest() {}
     16 
     17  private:
     18   DISALLOW_COPY_AND_ASSIGN(DictionarySyncPerfTest);
     19 };
     20 
     21 IN_PROC_BROWSER_TEST_F(DictionarySyncPerfTest, P0) {
     22   ASSERT_TRUE(SetupSync()) << "SetupSync() failed.";
     23   dictionary_helper::LoadDictionaries();
     24   ASSERT_TRUE(dictionary_helper::DictionariesMatch());
     25 
     26   base::TimeDelta dt;
     27   for (size_t i = 0;
     28        i < chrome::spellcheck_common::MAX_SYNCABLE_DICTIONARY_WORDS;
     29        ++i) {
     30     ASSERT_TRUE(dictionary_helper::AddWord(
     31         0, "foo" + base::Uint64ToString(i)));
     32   }
     33   dt = SyncTimingHelper::TimeMutualSyncCycle(GetClient(0), GetClient(1));
     34   ASSERT_EQ(chrome::spellcheck_common::MAX_SYNCABLE_DICTIONARY_WORDS,
     35             dictionary_helper::GetDictionarySize(1));
     36   SyncTimingHelper::PrintResult("dictionary", "add_words", dt);
     37 
     38   for (size_t i = 0;
     39        i < chrome::spellcheck_common::MAX_SYNCABLE_DICTIONARY_WORDS;
     40        ++i) {
     41     ASSERT_TRUE(dictionary_helper::RemoveWord(
     42         0, "foo" + base::Uint64ToString(i)));
     43   }
     44   dt = SyncTimingHelper::TimeMutualSyncCycle(GetClient(0), GetClient(1));
     45   ASSERT_EQ(0UL, dictionary_helper::GetDictionarySize(1));
     46   SyncTimingHelper::PrintResult("dictionary", "remove_words", dt);
     47 }
     48