15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/chromeos/contacts/gdata_contacts_service_stub.h"
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <vector>
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/chromeos/contacts/contact.pb.h"
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/chromeos/contacts/contact_test_util.h"
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/browser/browser_thread.h"
12a3f6a49ab37290eeeb8db0f41ec0f1cb74a68be7Torne (Richard Coles)#include "google_apis/drive/time_util.h"
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)using content::BrowserThread;
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace contacts {
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)GDataContactsServiceStub::GDataContactsServiceStub()
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    : num_download_requests_(0),
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      num_download_requests_with_wrong_timestamps_(0),
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      download_should_succeed_(true) {
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)GDataContactsServiceStub::~GDataContactsServiceStub() {
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void GDataContactsServiceStub::SetContacts(
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const contacts::ContactPointers& contacts,
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const base::Time& expected_min_update_time) {
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  contacts::test::CopyContacts(contacts, &contacts_);
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_min_update_time_ = expected_min_update_time;
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void GDataContactsServiceStub::DownloadContacts(
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    SuccessCallback success_callback,
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    FailureCallback failure_callback,
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const base::Time& min_update_time) {
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  CHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  num_download_requests_++;
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (!download_should_succeed_) {
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    failure_callback.Run();
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    return;
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (min_update_time != expected_min_update_time_) {
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    LOG(ERROR) << "Actual minimum update time ("
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               << google_apis::util::FormatTimeAsString(min_update_time) << ") "
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               << "differed from expected ("
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               << google_apis::util::FormatTimeAsString(
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                   expected_min_update_time_)
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               << "); not returning any contacts";
535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    num_download_requests_with_wrong_timestamps_++;
545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    failure_callback.Run();
555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    return;
565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  scoped_ptr<ScopedVector<contacts::Contact> > contacts(
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      new ScopedVector<contacts::Contact>());
605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  contacts::test::CopyContacts(contacts_, contacts.get());
615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  success_callback.Run(contacts.Pass());
625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace contacts
65