/*
* Copyright © 2019, 2020, 2021, 2022, 2023 Peter Doornbosch
*
* This file is part of Agent15, an implementation of TLS 1.3 in Java.
*
* Agent15 is free software: you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation, either version 3 of the License, or (at your option)
* any later version.
*
* Agent15 is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
* more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*/
package net.luminis.tls.handshake;
import net.luminis.tls.CertificateUtils;
import net.luminis.tls.alert.BadCertificateAlert;
import net.luminis.tls.alert.DecodeErrorException;
import net.luminis.tls.handshake.CertificateMessage;
import net.luminis.tls.util.ByteUtils;
import org.junit.jupiter.api.Test;
import java.nio.ByteBuffer;
import java.security.cert.X509Certificate;
import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
public class CertificateMessageTest {
@Test
void parseCertificateMessage() throws Exception {
byte[] rawData = ByteUtils.hexToBytes(gmailCertificateMessageBytes);
CertificateMessage cm = new CertificateMessage();
cm.parse(ByteBuffer.wrap(rawData));
assertThat(cm.getEndEntityCertificate()).isNotNull();
assertThat(cm.getCertificateChain()).hasSizeGreaterThan(1);
// Verify that certificate can be generated.
List