/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* 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.
*/
/*
* @test
* @bug 4160195 7026346
* @summary Check for correct detection of XML content type, including BOM streams
*/
public class GetXmlContentType {
// guess type from content and filename
"xml1", // US-ASCII and supersets
"xml2.xml", // typed inferred from filename
"xml3", // UTF-16 little endian (partial)
"xml4" // UTF-16 big endian (partial)
};
// some common non-XML examples
"not-xml1",
"not-xml2"
};
if (failed > 0)
throw new RuntimeException (
}
// POSITIVE tests: good data --> good result
failed++;
} else {
passed++;
}
}
// NEGATIVE tests: bad data --> correct diagnostic
failed++;
} else {
passed++;
}
}
}
+ file.getCanonicalPath()
+ name);
return conn.getContentType();
}
{"UTF-8", "UTF-16BE", "UTF-16LE", "UTF-32BE", "UTF-32LE"};
failed++;
} else {
passed++;
}
}
}
}
switch (encoding) {
case "UTF-8" :
break;
case "UTF-16BE" :
break;
case "UTF-16LE" :
break;
case "UTF-32BE" :
(byte) 0xFE, (byte) 0xFF });
break;
case "UTF-32LE" :
(byte) 0x00, (byte) 0x00 });
}
return bos.toByteArray();
}
}