| OLD | NEW |
| (Empty) |
| 1 #!/usr/bin/python | |
| 2 # Copyright (c) 2016 The Chromium Authors. All rights reserved. | |
| 3 # Use of this source code is governed by a BSD-style license that can be | |
| 4 # found in the LICENSE file. | |
| 5 | |
| 6 """A certificate tree with two self-signed root certificates(oldroot, newroot), | |
| 7 and a third root certificate (newrootrollover) which has the same key as newroot | |
| 8 but is signed by oldroot, all with the same subject and issuer. | |
| 9 There are two intermediates with the same key, subject and issuer | |
| 10 (oldintermediate signed by oldroot, and newintermediate signed by newroot). | |
| 11 The target certificate is signed by the intermediate key. | |
| 12 | |
| 13 | |
| 14 In graphical form: | |
| 15 | |
| 16 oldroot-------->newrootrollover newroot | |
| 17 | | | | |
| 18 v v v | |
| 19 oldintermediate newintermediate | |
| 20 | | | |
| 21 +------------+-------------+ | |
| 22 | | |
| 23 v | |
| 24 target | |
| 25 | |
| 26 | |
| 27 Several chains are output: | |
| 28 key-rollover-oldchain.pem: | |
| 29 target<-oldintermediate<-oldroot | |
| 30 key-rollover-rolloverchain.pem: | |
| 31 target<-newintermediate<-newrootrollover<-oldroot | |
| 32 key-rollover-longrolloverchain.pem: | |
| 33 target<-newintermediate<-newroot<-newrootrollover<-oldroot | |
| 34 key-rollover-newchain.pem: | |
| 35 target<-newintermediate<-newroot | |
| 36 | |
| 37 All of these chains should verify successfully. | |
| 38 """ | |
| 39 | |
| 40 import common | |
| 41 | |
| 42 # The new certs should have a newer notbefore date than "old" certs. This should | |
| 43 # affect path builder sorting, but otherwise won't matter. | |
| 44 JANUARY_2_2015_UTC = '150102120000Z' | |
| 45 | |
| 46 # Self-signed root certificates. Same name, different keys. | |
| 47 oldroot = common.create_self_signed_root_certificate('Root') | |
| 48 oldroot.set_validity_range(common.JANUARY_1_2015_UTC, common.JANUARY_1_2016_UTC) | |
| 49 newroot = common.create_self_signed_root_certificate('Root') | |
| 50 newroot.set_validity_range(JANUARY_2_2015_UTC, common.JANUARY_1_2016_UTC) | |
| 51 # Root with the new key signed by the old key. | |
| 52 newrootrollover = common.create_intermediate_certificate('Root', oldroot) | |
| 53 newrootrollover.set_key(newroot.get_key()) | |
| 54 newrootrollover.set_validity_range(JANUARY_2_2015_UTC, | |
| 55 common.JANUARY_1_2016_UTC) | |
| 56 | |
| 57 # Intermediate signed by oldroot. | |
| 58 oldintermediate = common.create_intermediate_certificate('Intermediate', | |
| 59 oldroot) | |
| 60 oldintermediate.set_validity_range(common.JANUARY_1_2015_UTC, | |
| 61 common.JANUARY_1_2016_UTC) | |
| 62 # Intermediate signed by newroot. Same key as oldintermediate. | |
| 63 newintermediate = common.create_intermediate_certificate('Intermediate', | |
| 64 newroot) | |
| 65 newintermediate.set_key(oldintermediate.get_key()) | |
| 66 newintermediate.set_validity_range(JANUARY_2_2015_UTC, | |
| 67 common.JANUARY_1_2016_UTC) | |
| 68 | |
| 69 # Target certificate. | |
| 70 target = common.create_end_entity_certificate('Target', oldintermediate) | |
| 71 | |
| 72 oldchain = [target, oldintermediate] | |
| 73 rolloverchain = [target, newintermediate, newrootrollover] | |
| 74 longrolloverchain = [target, newintermediate, newroot, newrootrollover] | |
| 75 oldtrusted = common.TrustAnchor(oldroot, constrained=False) | |
| 76 | |
| 77 newchain = [target, newintermediate] | |
| 78 newtrusted = common.TrustAnchor(newroot, constrained=False) | |
| 79 | |
| 80 time = common.DEFAULT_TIME | |
| 81 key_purpose = common.DEFAULT_KEY_PURPOSE | |
| 82 verify_result = True | |
| 83 errors = None | |
| 84 | |
| 85 common.write_test_file(__doc__, oldchain, oldtrusted, time, key_purpose, | |
| 86 verify_result, errors, | |
| 87 out_pem="key-rollover-oldchain.pem") | |
| 88 common.write_test_file(__doc__, rolloverchain, oldtrusted, time, key_purpose, | |
| 89 verify_result, errors, | |
| 90 out_pem="key-rollover-rolloverchain.pem") | |
| 91 common.write_test_file(__doc__, longrolloverchain, oldtrusted, time, | |
| 92 key_purpose, verify_result, errors, | |
| 93 out_pem="key-rollover-longrolloverchain.pem") | |
| 94 common.write_test_file(__doc__, newchain, newtrusted, time, key_purpose, | |
| 95 verify_result, errors, | |
| 96 out_pem="key-rollover-newchain.pem") | |
| OLD | NEW |