1 // Copyright 2013 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 #ifndef CHROMEOS_DBUS_FAKE_NFC_RECORD_CLIENT_H_
6 #define CHROMEOS_DBUS_FAKE_NFC_RECORD_CLIENT_H_
8 #include "base/memory/scoped_ptr.h"
9 #include "base/observer_list.h"
10 #include "base/values.h"
11 #include "chromeos/chromeos_export.h"
12 #include "chromeos/dbus/nfc_record_client.h"
13 #include "dbus/object_path.h"
17 // FakeNfcRecordClient simulates the behavior of the NFC record objects and is
18 // used both in test cases in place of a mock and on the Linux desktop.
19 class CHROMEOS_EXPORT FakeNfcRecordClient
: public NfcRecordClient
{
21 // Paths of the records exposed.
22 static const char kDeviceSmartPosterRecordPath
[];
23 static const char kDeviceTextRecordPath
[];
24 static const char kDeviceUriRecordPath
[];
25 static const char kTagRecordPath
[];
27 // Properties structure that provides fake behavior for D-Bus calls.
28 struct Properties
: public NfcRecordClient::Properties
{
29 explicit Properties(const PropertyChangedCallback
& callback
);
30 virtual ~Properties();
32 // dbus::PropertySet overrides.
33 virtual void Get(dbus::PropertyBase
* property
,
34 dbus::PropertySet::GetCallback callback
) OVERRIDE
;
35 virtual void GetAll() OVERRIDE
;
36 virtual void Set(dbus::PropertyBase
* property
,
37 dbus::PropertySet::SetCallback callback
) OVERRIDE
;
40 FakeNfcRecordClient();
41 virtual ~FakeNfcRecordClient();
43 // NfcTagClient overrides.
44 virtual void Init(dbus::Bus
* bus
) OVERRIDE
;
45 virtual void AddObserver(Observer
* observer
) OVERRIDE
;
46 virtual void RemoveObserver(Observer
* observer
) OVERRIDE
;
47 virtual std::vector
<dbus::ObjectPath
> GetRecordsForDevice(
48 const dbus::ObjectPath
& device_path
) OVERRIDE
;
49 virtual std::vector
<dbus::ObjectPath
> GetRecordsForTag(
50 const dbus::ObjectPath
& tag_path
) OVERRIDE
;
51 virtual Properties
* GetProperties(
52 const dbus::ObjectPath
& object_path
) OVERRIDE
;
54 // Adds or removes the fake record objects and notifies the observers.
55 void SetDeviceRecordsVisible(bool visible
);
56 void SetTagRecordsVisible(bool visible
);
58 // Modifies the contents of the tag record. |attributes| should be the
59 // same as the argument to NfcTagClient::Write. Each field will be directly
60 // assigned to the underlying record based on the type property, with
61 // no validity checking. Invalid tag content can be passed here to test
62 // the case where the remote application returns an incorrectly formatted
64 bool WriteTagRecord(const base::DictionaryValue
& attributes
);
67 // Property changed callback passed when we create Properties* structures.
68 void OnPropertyChanged(const dbus::ObjectPath
& object_path
,
69 const std::string
& property_name
);
71 // Called by Properties* structures when GetAll is called.
72 void OnPropertiesReceived(const dbus::ObjectPath
& object_path
);
74 // If true, the records are currently visible.
75 bool device_records_visible_
;
76 bool tag_records_visible_
;
78 // List of observers interested in event notifications from us.
79 ObserverList
<Observer
> observers_
;
81 // Fake properties that are returned for the fake records.
82 scoped_ptr
<Properties
> device_smart_poster_record_properties_
;
83 scoped_ptr
<Properties
> device_text_record_properties_
;
84 scoped_ptr
<Properties
> device_uri_record_properties_
;
85 scoped_ptr
<Properties
> tag_record_properties_
;
87 DISALLOW_COPY_AND_ASSIGN(FakeNfcRecordClient
);
90 } // namespace chromeos
92 #endif // CHROMEOS_DBUS_FAKE_NFC_RECORD_CLIENT_H_