1 // Copyright (c) 2012 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.
5 // A tool making it easier to create IDs for unit testing.
7 #ifndef SYNC_TEST_ENGINE_TEST_ID_FACTORY_H_
8 #define SYNC_TEST_ENGINE_TEST_ID_FACTORY_H_
12 #include "base/strings/string_number_conversions.h"
13 #include "sync/syncable/syncable_id.h"
19 TestIdFactory() : next_value_(1337000) {}
23 static syncable::Id
root() {
24 return syncable::Id();
27 // Make an ID from a number. If the number is zero, return the root ID.
28 // If the number is positive, create a server ID based on the value. If
29 // the number is negative, create a local ID based on the value. This
30 // is deterministic, and [FromNumber(X) == FromNumber(Y)] iff [X == Y].
31 static syncable::Id
FromNumber(int64 value
) {
35 return syncable::Id::CreateFromClientString(base::Int64ToString(value
));
37 return syncable::Id::CreateFromServerId(base::Int64ToString(value
));
40 // Create a local ID from a name.
41 static syncable::Id
MakeLocal(std::string name
) {
42 return syncable::Id::CreateFromClientString(std::string("lient ") + name
);
45 // Create a server ID from a string name.
46 static syncable::Id
MakeServer(std::string name
) {
47 return syncable::Id::CreateFromServerId(std::string("erver ") + name
);
50 // Autogenerate a fresh local ID.
51 syncable::Id
NewLocalId() {
52 return syncable::Id::CreateFromClientString(
53 std::string("_auto ") + base::IntToString(-next_value()));
56 // Autogenerate a fresh server ID.
57 syncable::Id
NewServerId() {
58 return syncable::Id::CreateFromServerId(
59 std::string("_auto ") + base::IntToString(next_value()));
71 #endif // SYNC_TEST_ENGINE_TEST_ID_FACTORY_H_