blob: 2a44b89ff193de56b0f873aec1ce2132a1f99cb3 [file] [log] [blame]
/*
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code 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 General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import javax.sound.sampled.AudioFormat;
import javax.sound.sampled.AudioFormat.Encoding;
import javax.sound.sampled.AudioSystem;
import javax.sound.sampled.spi.FormatConversionProvider;
import static java.util.ServiceLoader.load;
/**
* @test
* @bug 8146144
*/
public final class GetTargetIsSupported {
/**
* We will try to use all formats, in this case all our providers will be
* covered by supported/unsupported formats.
*/
private static final List<AudioFormat> formats = new ArrayList<>(23000);
private static final Encoding[] encodings = {
Encoding.ALAW, Encoding.ULAW, Encoding.PCM_SIGNED,
Encoding.PCM_UNSIGNED, Encoding.PCM_FLOAT, new Encoding("Test")
};
private static final int[] sampleRates = {
AudioSystem.NOT_SPECIFIED, 8000, 11025, 16000, 22050, 32000, 37800,
44056, 44100, 47250, 48000, 50000, 50400, 88200, 96000, 176400,
192000, 352800, 2822400, 5644800
};
private static final int[] sampleBits = {
AudioSystem.NOT_SPECIFIED, 4, 8, 11, 16, 20, 24, 32, 48, 64, 128
};
private static final int[] channels = {
AudioSystem.NOT_SPECIFIED, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
};
static {
for (final Boolean end : new boolean[]{false, true}) {
for (final int sampleSize : sampleBits) {
for (final int sampleRate : sampleRates) {
for (final int channel : channels) {
for (final Encoding enc : encodings) {
formats.add(new AudioFormat(enc, sampleRate,
sampleSize, channel,
1, sampleRate, end));
}
}
}
}
}
}
public static void main(final String[] args) {
for (final AudioFormat format : formats) {
testAS(format);
for (final FormatConversionProvider fcp : load
(FormatConversionProvider.class)) {
testFCP(fcp, format);
}
}
}
/**
* Tests the part of AudioSystem API, which implemented via
* FormatConversionProvider.
*
* @see AudioSystem#getTargetEncodings(Encoding)
* @see AudioSystem#getTargetEncodings(AudioFormat)
* @see AudioSystem#getTargetFormats(Encoding, AudioFormat)
* @see AudioSystem#isConversionSupported(AudioFormat, AudioFormat)
* @see AudioSystem#isConversionSupported(Encoding, AudioFormat)
*/
private static void testAS(final AudioFormat source) {
Encoding[] all = AudioSystem.getTargetEncodings(source.getEncoding());
Encoding[] part = AudioSystem.getTargetEncodings(source);
// Check encodings which are reported as supported
for (final Encoding enc : part) {
// If encoding is reported for the source format means that
// the list of target formats should not be empty
AudioFormat[] targets = AudioSystem.getTargetFormats(enc, source);
// all reported formats should be supported
for (final AudioFormat target : targets) {
if (!AudioSystem.isConversionSupported(target, source)) {
throw new RuntimeException("Error:" + enc);
}
if (!enc.equals(target.getEncoding())) {
throw new RuntimeException("Error:" + enc);
}
}
// If encoding is reported for the source format means that
// conversion source -> encoding is supported
if (!AudioSystem.isConversionSupported(enc, source)) {
throw new RuntimeException("Error:" + enc);
}
// encoding for a particular source should be included in the
// list of all encodings for the source's encoding
if (!Arrays.asList(all).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
// If conversion source -> encoding is supported then an
// array of target formats should not be empty
if (source.getEncoding().equals(enc)) {
// this is unspecified but we works this way
if (!isContains(source, targets)) {
throw new RuntimeException("Error:" + enc);
}
} else {
if (targets.length == 0) {
throw new RuntimeException("Error:" + enc);
}
}
}
// Check all encodings
for (final Encoding enc : encodings) {
AudioFormat[] targets = AudioSystem.getTargetFormats(enc, source);
// If target format is reported for the source format means that
// conversion source -> target is supported
for (final AudioFormat target : targets) {
if (!AudioSystem.isConversionSupported(target, source)) {
throw new RuntimeException("Error:" + enc);
}
if (!enc.equals(target.getEncoding())) {
throw new RuntimeException("Error:" + enc);
}
}
if (AudioSystem.isConversionSupported(enc, source)) {
// encoding for a particular source should be included in the
// list of all encodings for the source's encoding
if (!Arrays.asList(all).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
if (!Arrays.asList(part).contains(enc)) {
System.out.println("enc = " + enc);
System.out.println("part = " + Arrays.toString(part));
System.out.println("source = " + source);
throw new RuntimeException("Error:" + enc);
}
// If conversion source -> encoding is supported then an
// array of target formats should not be empty
if (source.getEncoding().equals(enc)) {
// this is unspecified but we works this way
if (!isContains(source, targets)) {
throw new RuntimeException("Error:" + enc);
}
} else {
if (targets.length == 0) {
throw new RuntimeException("Error:" + enc);
}
}
} else {
// If conversion source -> encoding is not supported then an
// array of target formats should be empty
if (targets.length != 0) {
throw new RuntimeException("Error:" + enc);
}
if (Arrays.asList(part).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
}
}
}
/**
* Tests the FormatConversionProvider API directly.
*
* @see FormatConversionProvider#getTargetEncodings()
* @see FormatConversionProvider#getTargetEncodings(AudioFormat)
* @see FormatConversionProvider#getTargetFormats(Encoding, AudioFormat)
* @see FormatConversionProvider#isTargetEncodingSupported(Encoding)
* @see FormatConversionProvider#isConversionSupported(Encoding,
* AudioFormat)
* @see FormatConversionProvider#isConversionSupported(AudioFormat,
* AudioFormat)
*/
private static void testFCP(final FormatConversionProvider fcp,
final AudioFormat source) {
final Encoding[] all = fcp.getTargetEncodings();
for (final Encoding enc : all) {
if (!fcp.isTargetEncodingSupported(enc)) {
throw new RuntimeException("Error:" + enc);
}
}
// Check encodings which are reported as supported
final Encoding[] part = fcp.getTargetEncodings(source);
for (final Encoding enc : part) {
// If encoding is reported for the source format means that
// the list of target formats should not be empty for this encoding
AudioFormat[] targets = fcp.getTargetFormats(enc, source);
// all reported formats should be supported
for (final AudioFormat target : targets) {
if (!fcp.isConversionSupported(target, source)) {
throw new RuntimeException("Error:" + enc);
}
if (!enc.equals(target.getEncoding())) {
throw new RuntimeException("Error:" + enc);
}
}
// If encoding is reported for the source format means that
// conversion source -> encoding is supported
if (!fcp.isConversionSupported(enc, source)) {
throw new RuntimeException("Error:" + enc);
}
// If conversion source -> encoding is supported then an
// array of target formats should not be empty
if (targets.length == 0) {
throw new RuntimeException("Error:" + enc);
}
// encoding for a particular source should be included in the
// list of all encodings for the source's encoding
if (!Arrays.asList(all).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
}
// Check all encodings
for (final Encoding enc : encodings) {
AudioFormat[] targets = fcp.getTargetFormats(enc, source);
// If target format is reported for the source format means that
// conversion source -> target is supported
for (final AudioFormat target : targets) {
if (!fcp.isConversionSupported(target, source)) {
throw new RuntimeException("Error:" + enc);
}
if (!enc.equals(target.getEncoding())) {
throw new RuntimeException("Error:" + enc);
}
}
if (fcp.isConversionSupported(enc, source)) {
// If conversion source -> encoding is supported then an
// array of target formats should not be empty
if (targets.length == 0) {
throw new RuntimeException("Error:" + enc);
}
// encoding for a particular source should be included in the
// list of all encodings for the source's encoding
if (!Arrays.asList(all).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
if (!Arrays.asList(part).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
} else {
// If conversion source -> encoding is not supported then an
// array of target formats should be empty
if (targets.length != 0) {
throw new RuntimeException("Error:" + enc);
}
if (Arrays.asList(part).contains(enc)) {
throw new RuntimeException("Error:" + enc);
}
}
}
}
private static boolean isContains(AudioFormat obj, AudioFormat[] array) {
for (final AudioFormat format : array) {
if (obj.matches(format)) {
return true;
}
}
return false;
}
}