blob: 289a3beab948138be3ea1160c44de867b7abe49d [file] [log] [blame]
/*
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.server.wifi;
import static org.junit.Assert.*;
import static org.mockito.Mockito.*;
import android.support.test.filters.SmallTest;
import android.util.Xml;
import com.android.internal.util.FastXmlSerializer;
import org.junit.Before;
import org.junit.Test;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlSerializer;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.nio.charset.StandardCharsets;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
/**
* Unit tests for {@link com.android.server.wifi.DeletedEphemeralSsidsStoreData}.
*/
@SmallTest
public class DeletedEphemeralSsidsStoreDataTest {
private static final String TEST_SSID1 = "SSID 1";
private static final String TEST_SSID2 = "SSID 2";
private static final String TEST_SSID_LIST_XML_STRING =
"<set name=\"SSIDList\">\n"
+ "<string>" + TEST_SSID1 + "</string>\n"
+ "<string>" + TEST_SSID2 + "</string>\n"
+ "</set>\n";
private static final byte[] TEST_SSID_LIST_XML_BYTES =
TEST_SSID_LIST_XML_STRING.getBytes(StandardCharsets.UTF_8);
private DeletedEphemeralSsidsStoreData mDeletedEphemeralSsidsStoreData;
@Before
public void setUp() throws Exception {
mDeletedEphemeralSsidsStoreData = new DeletedEphemeralSsidsStoreData();
}
/**
* Helper function for serializing configuration data to a XML block.
*
* @param shared Flag indicating serializing shared or user configurations
* @return byte[] of the XML data
* @throws Exception
*/
private byte[] serializeData(boolean shared) throws Exception {
final XmlSerializer out = new FastXmlSerializer();
final ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
out.setOutput(outputStream, StandardCharsets.UTF_8.name());
mDeletedEphemeralSsidsStoreData.serializeData(out, shared);
out.flush();
return outputStream.toByteArray();
}
/**
* Helper function for parsing configuration data from a XML block.
*
* @param data XML data to parse from
* @param shared Flag indicating parsing of shared or user configurations
* @return SSID list
* @throws Exception
*/
private Set<String> deserializeData(byte[] data, boolean shared) throws Exception {
final XmlPullParser in = Xml.newPullParser();
final ByteArrayInputStream inputStream = new ByteArrayInputStream(data);
in.setInput(inputStream, StandardCharsets.UTF_8.name());
mDeletedEphemeralSsidsStoreData.deserializeData(in, in.getDepth(), shared);
return mDeletedEphemeralSsidsStoreData.getSsidList();
}
/**
* Verify that a XmlPullParserException will be thrown when attempting to serialize SSID list
* to the share store, since the deleted ephemeral SSID list should never be persist
* to the share store.
*
* @throws Exception
*/
@Test(expected = XmlPullParserException.class)
public void serializeShareData() throws Exception {
serializeData(true /* shared */);
}
/**
* Verify that a XmlPullParserException will be thrown when attempting to parse SSID list
* from the share store, since the deleted ephemeral SSID list should never be persist
* to the share store.
*
* @throws Exception
*/
@Test(expected = XmlPullParserException.class)
public void deserializeShareData() throws Exception {
deserializeData(new byte[0], true /* shared */);
}
/**
* Verify that serializing the user store data without any configuration doesn't cause any
* crash and no data should be serialized.
*
* @throws Exception
*/
@Test
public void serializeEmptyConfigs() throws Exception {
assertEquals(0, serializeData(false /* shared */).length);
}
/**
* Verify that parsing an empty data doesn't cause any crash and no configuration should
* be deserialized.
*
* @throws Exception
*/
@Test
public void deserializeEmptyData() throws Exception {
assertTrue(deserializeData(new byte[0], false /* shared */).isEmpty());
}
/**
* Verify that DeletedEphemeralSsidsStoreData does not support share data.
*
* @throws Exception
*/
@Test
public void supportShareData() throws Exception {
assertFalse(mDeletedEphemeralSsidsStoreData.supportShareData());
}
/**
* Verify that user store SSID list is serialized correctly, matches the predefined test
* XML data.
*
* @throws Exception
*/
@Test
public void serializeSsidList() throws Exception {
Set<String> ssidList = new HashSet<>();
ssidList.add(TEST_SSID1);
ssidList.add(TEST_SSID2);
mDeletedEphemeralSsidsStoreData.setSsidList(ssidList);
byte[] actualData = serializeData(false /* shared */);
assertTrue(Arrays.equals(TEST_SSID_LIST_XML_BYTES, actualData));
}
/**
* Verify that user store SSID list is deserialized correctly using the predefined test XML
* data.
*
* @throws Exception
*/
@Test
public void deserializeSsidList() throws Exception {
Set<String> ssidList = new HashSet<>();
ssidList.add(TEST_SSID1);
ssidList.add(TEST_SSID2);
assertEquals(ssidList, deserializeData(TEST_SSID_LIST_XML_BYTES, false /* shared */));
}
}