]> git.saurik.com Git - apple/security.git/blob - OSX/sec/SOSCircle/Regressions/sc-20-keynames.c
Security-57337.40.85.tar.gz
[apple/security.git] / OSX / sec / SOSCircle / Regressions / sc-20-keynames.c
1 /*
2 * Copyright (c) 2012-2014 Apple Inc. All Rights Reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24
25
26 #include <Security/SecBase.h>
27 #include <Security/SecItem.h>
28 #include <Security/SecKey.h>
29
30 #include <Security/SecureObjectSync/SOSAccount.h>
31 #include <Security/SecureObjectSync/SOSCircle.h>
32 #include <Security/SecureObjectSync/SOSPeerInfo.h>
33 #include <Security/SecureObjectSync/SOSInternal.h>
34 #include <Security/SecureObjectSync/SOSKVSKeys.h>
35 #include <utilities/SecCFWrappers.h>
36
37 #include <CoreFoundation/CoreFoundation.h>
38
39 #include <stdlib.h>
40 #include <unistd.h>
41
42 #include "SOSCircle_regressions.h"
43
44 #include "SOSRegressionUtilities.h"
45
46
47 static int kTestTestCount = 15;
48 static void tests(void)
49 {
50 SecKeyRef publicKey = NULL;
51
52 CFErrorRef error = NULL;
53 SOSCircleRef circle = SOSCircleCreate(NULL, CFSTR("Test Circle"), &error);
54
55 CFStringRef circle_key = SOSCircleKeyCreateWithCircle(circle, NULL);
56
57 CFStringRef circle_name = NULL;
58 ok(circle_key, "Circle key created");
59 is(SOSKVSKeyGetKeyType(circle_key), kCircleKey, "Is circle key");
60 is(SOSKVSKeyGetKeyTypeAndParse(circle_key, &circle_name, NULL, NULL, NULL, NULL, NULL), kCircleKey, "Is circle key, extract name");
61 ok(circle_name, "Circle name extracted");
62 ok(CFEqualSafe(circle_name, SOSCircleGetName(circle)), "Circle name matches '%@' '%@'", circle_name, SOSCircleGetName(circle));
63
64 CFReleaseSafe(circle_key);
65
66 SOSPeerInfoRef pi = SOSCreatePeerInfoFromName(CFSTR("Test Peer"), &publicKey, &error);
67
68 CFStringRef other_peer_id = CFSTR("OTHER PEER");
69
70 CFStringRef messageKey = SOSMessageKeyCreateWithCircleAndPeerNames(circle, SOSPeerInfoGetPeerID(pi), other_peer_id);
71
72 ok(messageKey, "Getting message key '%@'", messageKey);
73
74 CFStringRef message_circle_name = NULL;
75 CFStringRef message_from_peer_id = NULL;
76 CFStringRef message_to_peer_id = NULL;
77 CFStringRef message_ring = NULL;
78 CFStringRef message_peer_info = NULL;
79 CFStringRef message_backup = NULL;
80
81 is(SOSKVSKeyGetKeyType(messageKey), kMessageKey, "Is message key");
82 is(SOSKVSKeyGetKeyTypeAndParse(messageKey,
83 &message_circle_name,
84 &message_peer_info,
85 &message_ring,
86 &message_backup,
87 &message_from_peer_id,
88 &message_to_peer_id), kMessageKey, "Is message key, extract parts");
89
90
91 ok(CFEqualSafe(SOSCircleGetName(circle), message_circle_name), "circle key matches in message (%@ v %@)",SOSCircleGetName(circle), message_circle_name);
92
93
94 ok(CFEqualSafe(SOSPeerInfoGetPeerID(pi), message_from_peer_id), "from peer set correctly (%@ v %@)", SOSPeerInfoGetPeerID(pi), message_from_peer_id);
95
96 ok(CFEqualSafe(other_peer_id, message_to_peer_id), "to peer set correctly (%@ v %@)", other_peer_id, message_to_peer_id);
97
98 CFStringRef retirementKey = SOSRetirementKeyCreateWithCircleAndPeer(circle, SOSPeerInfoGetPeerID(pi));
99 CFStringRef retirement_circle_name = NULL;
100 CFStringRef retirement_peer_id = NULL;
101
102 is(SOSKVSKeyGetKeyType(retirementKey), kRetirementKey, "Is retirement key");
103 is(SOSKVSKeyGetKeyTypeAndParse(retirementKey,
104 &retirement_circle_name,
105 NULL,
106 NULL,
107 NULL,
108 &retirement_peer_id,
109 NULL), kRetirementKey, "Is retirement key, extract parts");
110 CFReleaseSafe(retirementKey);
111 ok(CFEqualSafe(SOSCircleGetName(circle), retirement_circle_name), "circle key matches in retirement (%@ v %@)",
112 SOSCircleGetName(circle), retirement_circle_name);
113 ok(CFEqualSafe(SOSPeerInfoGetPeerID(pi), retirement_peer_id), "retirement peer set correctly (%@ v %@)",
114 SOSPeerInfoGetPeerID(pi), retirement_peer_id);
115
116 CFReleaseNull(publicKey);
117 CFReleaseNull(circle);
118 CFReleaseNull(error);
119 CFReleaseNull(pi);
120 CFReleaseNull(messageKey);
121 CFReleaseNull(message_circle_name);
122 CFReleaseNull(message_from_peer_id);
123 CFReleaseNull(message_to_peer_id);
124 }
125
126 int sc_20_keynames(int argc, char *const *argv)
127 {
128 plan_tests(kTestTestCount);
129
130 tests();
131
132 return 0;
133 }