blob: c214286de9d8cbfa21bc51526cbef5242e338a5c [file] [log] [blame]
// Copyright 2014 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.
#ifndef SYNC_TEST_FAKE_SERVER_FAKE_SERVER_VERIFIER_H_
#define SYNC_TEST_FAKE_SERVER_FAKE_SERVER_VERIFIER_H_
#include <string>
#include "base/memory/scoped_ptr.h"
#include "base/values.h"
#include "sync/internal_api/public/base/model_type.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace fake_server {
class FakeServer;
// Provides methods to verify the state of a FakeServer. The main use case of
// this class is verifying committed data so that it does not have to be synced
// down to another test client for verification. These methods are not present
// on FakeServer so that its interface is not polluted.
class FakeServerVerifier {
public:
// Creates a FakeServerVerifier for |fake_server|. This class does not take
// ownership of |fake_server|.
explicit FakeServerVerifier(FakeServer* fake_server);
virtual ~FakeServerVerifier();
// Returns a successful result if there are |expected_count| entities with the
// given |model_type|. A failure is returned if the count does not match or
// verification can't take place.
testing::AssertionResult VerifyEntityCountByType(
size_t expected_count,
syncer::ModelType model_type) const;
// Returns a successful result if there are |expected_count| entities with the
// given |model_type| and |name|. A failure is returned if the count does not
// match or verification can't take place.
testing::AssertionResult VerifyEntityCountByTypeAndName(
size_t expected_count,
syncer::ModelType model_type,
const std::string& name) const;
private:
FakeServer* const fake_server_;
DISALLOW_COPY_AND_ASSIGN(FakeServerVerifier);
};
} // namespace fake_server
#endif // SYNC_TEST_FAKE_SERVER_FAKE_SERVER_VERIFIER_H_