1 #include "config.h"
2 #include <common/setup.h>
3 #include <stdio.h>
4 #include "../amount.c"
5 #include "../psbt_open.c"
6 
7 /* AUTOGENERATED MOCKS START */
8 /* Generated stub for fromwire */
fromwire(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED,void * copy UNNEEDED,size_t n UNNEEDED)9 const u8 *fromwire(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, void *copy UNNEEDED, size_t n UNNEEDED)
10 { fprintf(stderr, "fromwire called!\n"); abort(); }
11 /* Generated stub for fromwire_bool */
fromwire_bool(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED)12 bool fromwire_bool(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
13 { fprintf(stderr, "fromwire_bool called!\n"); abort(); }
14 /* Generated stub for fromwire_fail */
fromwire_fail(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED)15 void *fromwire_fail(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
16 { fprintf(stderr, "fromwire_fail called!\n"); abort(); }
17 /* Generated stub for fromwire_secp256k1_ecdsa_signature */
fromwire_secp256k1_ecdsa_signature(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED,secp256k1_ecdsa_signature * signature UNNEEDED)18 void fromwire_secp256k1_ecdsa_signature(const u8 **cursor UNNEEDED, size_t *max UNNEEDED,
19 					secp256k1_ecdsa_signature *signature UNNEEDED)
20 { fprintf(stderr, "fromwire_secp256k1_ecdsa_signature called!\n"); abort(); }
21 /* Generated stub for fromwire_sha256 */
fromwire_sha256(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED,struct sha256 * sha256 UNNEEDED)22 void fromwire_sha256(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, struct sha256 *sha256 UNNEEDED)
23 { fprintf(stderr, "fromwire_sha256 called!\n"); abort(); }
24 /* Generated stub for fromwire_tal_arrn */
fromwire_tal_arrn(const tal_t * ctx UNNEEDED,const u8 ** cursor UNNEEDED,size_t * max UNNEEDED,size_t num UNNEEDED)25 u8 *fromwire_tal_arrn(const tal_t *ctx UNNEEDED,
26 		       const u8 **cursor UNNEEDED, size_t *max UNNEEDED, size_t num UNNEEDED)
27 { fprintf(stderr, "fromwire_tal_arrn called!\n"); abort(); }
28 /* Generated stub for fromwire_u16 */
fromwire_u16(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED)29 u16 fromwire_u16(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
30 { fprintf(stderr, "fromwire_u16 called!\n"); abort(); }
31 /* Generated stub for fromwire_u32 */
fromwire_u32(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED)32 u32 fromwire_u32(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
33 { fprintf(stderr, "fromwire_u32 called!\n"); abort(); }
34 /* Generated stub for fromwire_u64 */
fromwire_u64(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED)35 u64 fromwire_u64(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
36 { fprintf(stderr, "fromwire_u64 called!\n"); abort(); }
37 /* Generated stub for fromwire_u8 */
fromwire_u8(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED)38 u8 fromwire_u8(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
39 { fprintf(stderr, "fromwire_u8 called!\n"); abort(); }
40 /* Generated stub for fromwire_u8_array */
fromwire_u8_array(const u8 ** cursor UNNEEDED,size_t * max UNNEEDED,u8 * arr UNNEEDED,size_t num UNNEEDED)41 void fromwire_u8_array(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, u8 *arr UNNEEDED, size_t num UNNEEDED)
42 { fprintf(stderr, "fromwire_u8_array called!\n"); abort(); }
43 /* Generated stub for pseudorand_u64 */
pseudorand_u64(void)44 uint64_t pseudorand_u64(void)
45 { fprintf(stderr, "pseudorand_u64 called!\n"); abort(); }
46 /* Generated stub for towire */
towire(u8 ** pptr UNNEEDED,const void * data UNNEEDED,size_t len UNNEEDED)47 void towire(u8 **pptr UNNEEDED, const void *data UNNEEDED, size_t len UNNEEDED)
48 { fprintf(stderr, "towire called!\n"); abort(); }
49 /* Generated stub for towire_bool */
towire_bool(u8 ** pptr UNNEEDED,bool v UNNEEDED)50 void towire_bool(u8 **pptr UNNEEDED, bool v UNNEEDED)
51 { fprintf(stderr, "towire_bool called!\n"); abort(); }
52 /* Generated stub for towire_secp256k1_ecdsa_signature */
towire_secp256k1_ecdsa_signature(u8 ** pptr UNNEEDED,const secp256k1_ecdsa_signature * signature UNNEEDED)53 void towire_secp256k1_ecdsa_signature(u8 **pptr UNNEEDED,
54 			      const secp256k1_ecdsa_signature *signature UNNEEDED)
55 { fprintf(stderr, "towire_secp256k1_ecdsa_signature called!\n"); abort(); }
56 /* Generated stub for towire_sha256 */
towire_sha256(u8 ** pptr UNNEEDED,const struct sha256 * sha256 UNNEEDED)57 void towire_sha256(u8 **pptr UNNEEDED, const struct sha256 *sha256 UNNEEDED)
58 { fprintf(stderr, "towire_sha256 called!\n"); abort(); }
59 /* Generated stub for towire_u16 */
towire_u16(u8 ** pptr UNNEEDED,u16 v UNNEEDED)60 void towire_u16(u8 **pptr UNNEEDED, u16 v UNNEEDED)
61 { fprintf(stderr, "towire_u16 called!\n"); abort(); }
62 /* Generated stub for towire_u32 */
towire_u32(u8 ** pptr UNNEEDED,u32 v UNNEEDED)63 void towire_u32(u8 **pptr UNNEEDED, u32 v UNNEEDED)
64 { fprintf(stderr, "towire_u32 called!\n"); abort(); }
65 /* Generated stub for towire_u64 */
towire_u64(u8 ** pptr UNNEEDED,u64 v UNNEEDED)66 void towire_u64(u8 **pptr UNNEEDED, u64 v UNNEEDED)
67 { fprintf(stderr, "towire_u64 called!\n"); abort(); }
68 /* Generated stub for towire_u8 */
towire_u8(u8 ** pptr UNNEEDED,u8 v UNNEEDED)69 void towire_u8(u8 **pptr UNNEEDED, u8 v UNNEEDED)
70 { fprintf(stderr, "towire_u8 called!\n"); abort(); }
71 /* Generated stub for towire_u8_array */
towire_u8_array(u8 ** pptr UNNEEDED,const u8 * arr UNNEEDED,size_t num UNNEEDED)72 void towire_u8_array(u8 **pptr UNNEEDED, const u8 *arr UNNEEDED, size_t num UNNEEDED)
73 { fprintf(stderr, "towire_u8_array called!\n"); abort(); }
74 /* AUTOGENERATED MOCKS END */
75 
diff_count(struct wally_psbt * a,struct wally_psbt * b,size_t diff_added,size_t diff_rm)76 static void diff_count(struct wally_psbt *a,
77 		       struct wally_psbt *b,
78 		       size_t diff_added,
79 		       size_t diff_rm)
80 {
81 	struct psbt_changeset *set;
82 
83 	set = psbt_get_changeset(tmpctx, a, b);
84 
85 	assert(tal_count(set->added_ins) == diff_added);
86 	assert(tal_count(set->added_outs) == diff_added);
87 	assert(tal_count(set->rm_ins) == diff_rm);
88 	assert(tal_count(set->rm_outs) == diff_rm);
89 }
90 
add_in_out_with_serial(struct wally_psbt * psbt,size_t serial_id,size_t default_value)91 static void add_in_out_with_serial(struct wally_psbt *psbt,
92 				   size_t serial_id,
93 				   size_t default_value)
94 {
95 	struct bitcoin_outpoint outpoint;
96 	u8 *script;
97 	struct amount_sat sat;
98 	struct wally_psbt_input *in;
99 	struct wally_psbt_output *out;
100 
101 	memset(&outpoint, default_value, sizeof(outpoint));
102 	in = psbt_append_input(psbt, &outpoint, default_value,
103 			       NULL, NULL, NULL);
104 	if (!in)
105 		abort();
106 	psbt_input_set_serial_id(psbt, in, serial_id);
107 
108 	script = tal_arr(tmpctx, u8, 20);
109 	memset(script, default_value, 20);
110 	sat = amount_sat(default_value);
111 	out = psbt_append_output(psbt, script, sat);
112 	if (!out)
113 		abort();
114 	psbt_output_set_serial_id(psbt, out, serial_id);
115 }
116 
117 /* Try changing up the serial ids */
change_serials(void)118 static void change_serials(void)
119 {
120 	struct wally_psbt *psbt;
121 
122 	psbt = create_psbt(tmpctx, 1, 1, 0);
123 	add_in_out_with_serial(psbt, 10, 1);
124 
125 	psbt_output_set_serial_id(psbt, &psbt->outputs[0], 2);
126 	assert(psbt_find_serial_output(psbt, 2) == 0);
127 	assert(psbt_find_serial_output(psbt, 10) == -1);
128 
129 	psbt_input_set_serial_id(psbt, &psbt->inputs[0], 4);
130 	assert(psbt_find_serial_input(psbt, 4) == 0);
131 	assert(psbt_find_serial_input(psbt, 10) == -1);
132 
133 }
134 
check_psbt_comparison(void)135 static void check_psbt_comparison(void)
136 {
137 	struct wally_psbt *oldpsbt = psbt_from_b64(tmpctx, "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", strlen("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"));
138 
139 	struct wally_psbt *newpsbt = psbt_from_b64(tmpctx, "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", strlen("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"));
140 
141 	assert(!psbt_contribs_changed(oldpsbt, newpsbt));
142 }
143 
main(int argc,const char * argv[])144 int main(int argc, const char *argv[])
145 {
146 	common_setup(argv[0]);
147 
148 	struct wally_psbt *start, *end;
149 	u32 flags = 0;
150 
151 	chainparams = chainparams_for_network("bitcoin");
152 
153 	/* Create two psbts! */
154 	end = create_psbt(tmpctx, 1, 1, 0);
155 	tal_wally_start();
156 	if (wally_psbt_clone_alloc(end, flags, &start) != WALLY_OK)
157 		abort();
158 	tal_wally_end(tmpctx);
159 	diff_count(start, end, 0, 0);
160 	diff_count(end, start, 0, 0);
161 
162 	/* New input/output added */
163 	add_in_out_with_serial(end, 10, 1);
164 	diff_count(start, end, 1, 0);
165 	diff_count(end, start, 0, 1);
166 
167 	/* Add another one, before previous */
168 	tal_wally_start();
169 	if (wally_psbt_clone_alloc(end, flags, &start) != WALLY_OK)
170 		abort();
171 	tal_wally_end(tmpctx);
172 	add_in_out_with_serial(end, 5, 2);
173 	diff_count(start, end, 1, 0);
174 	diff_count(end, start, 0, 1);
175 
176 	/* Add another, at end */
177 	tal_wally_start();
178 	if (wally_psbt_clone_alloc(end, flags, &start) != WALLY_OK)
179 		abort();
180 	tal_wally_end(tmpctx);
181 	add_in_out_with_serial(end, 15, 3);
182 	diff_count(start, end, 1, 0);
183 	diff_count(end, start, 0, 1);
184 
185 	/* Add another, in middle */
186 	tal_wally_start();
187 	if (wally_psbt_clone_alloc(end, flags, &start) != WALLY_OK)
188 		abort();
189 	tal_wally_end(tmpctx);
190 	add_in_out_with_serial(end, 11, 4);
191 	diff_count(start, end, 1, 0);
192 	diff_count(end, start, 0, 1);
193 
194 	/* Change existing input/output info
195 	 * (we accomplish this by removing and then
196 	 * readding an input/output with the same serial_id
197 	 * but different value) */
198 	tal_wally_start();
199 	if (wally_psbt_clone_alloc(end, flags, &start) != WALLY_OK)
200 		abort();
201 	tal_wally_end(tmpctx);
202 	psbt_rm_output(end, 0);
203 	psbt_rm_input(end, 0);
204 	add_in_out_with_serial(end, 5, 5);
205 	diff_count(start, end, 1, 1);
206 	diff_count(end, start, 1, 1);
207 
208 	/* Add some extra unknown info to a PSBT */
209 	u8 *key = psbt_make_key(tmpctx, 0x05, NULL);
210 	char *val = tal_fmt(tmpctx, "hello");
211 	psbt_input_set_unknown(end, &end->inputs[1], key, val, tal_bytelen(val));
212 	psbt_input_set_unknown(start, &start->inputs[1], key, val, tal_bytelen(val));
213 
214 	/* Swap locations */
215 	struct wally_map_item tmp;
216 	tmp = end->inputs[1].unknowns.items[0];
217 	end->inputs[1].unknowns.items[0] = end->inputs[1].unknowns.items[1];
218 	end->inputs[1].unknowns.items[1] = tmp;
219 
220 	/* We expect nothing to change ? */
221 	diff_count(start, end, 1, 1);
222 	diff_count(end, start, 1, 1);
223 
224 	change_serials();
225 
226 	check_psbt_comparison();
227 
228 	/* No memory leaks please */
229 	common_shutdown();
230 	return 0;
231 }
232