/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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 org.apache.pdfbox.pdmodel.interactive.form; import java.io.IOException; import java.util.ArrayList; import java.util.List; import junit.framework.Test; import junit.framework.TestCase; import junit.framework.TestSuite; import org.apache.pdfbox.cos.COSArray; import org.apache.pdfbox.cos.COSName; import org.apache.pdfbox.pdmodel.PDDocument; /** * This will test the functionality of Radio Buttons in PDFBox. */ public class TestRadioButtons extends TestCase { /** * Constructor. * * @param name The name of the test to run. */ public TestRadioButtons( String name ) { super( name ); } /** * This will get the suite of test that this class holds. * * @return All of the tests that this class holds. */ public static Test suite() { return new TestSuite( TestRadioButtons.class ); } /** * infamous main method. * * @param args The command line arguments. */ public static void main( String[] args ) { String[] arg = {TestRadioButtons.class.getName() }; junit.textui.TestRunner.main( arg ); } /** * This will test the radio button PDModel. * * @throws IOException If there is an error creating the field. */ public void testRadioButtonPDModel() throws IOException { PDDocument doc = null; try { doc = new PDDocument(); PDAcroForm form = new PDAcroForm( doc ); PDRadioButton radioButton = new PDRadioButton(form); // test that there are no nulls returned for an empty field // only specific methods are tested here assertNotNull(radioButton.getDefaultValue()); assertNotNull(radioButton.getSelectedExportValues()); assertNotNull(radioButton.getExportValues()); assertNotNull(radioButton.getValue()); // Test setting/getting option values - the dictionaries Opt entry List<String> options = new ArrayList<>(); options.add("Value01"); options.add("Value02"); radioButton.setExportValues(options); COSArray optItem = (COSArray) radioButton.getCOSObject().getItem(COSName.OPT); // assert that the values have been correctly set assertNotNull(radioButton.getCOSObject().getItem(COSName.OPT)); assertEquals(optItem.size(),2); assertEquals(options.get(0), optItem.getString(0)); // assert that the values can be retrieved correctly List<String> retrievedOptions = radioButton.getExportValues(); assertEquals(retrievedOptions.size(),2); assertEquals(retrievedOptions, options); // assert that the Opt entry is removed radioButton.setExportValues(null); assertNull(radioButton.getCOSObject().getItem(COSName.OPT)); // if there is no Opt entry an empty List shall be returned assertEquals(radioButton.getExportValues(), new ArrayList<String>()); } finally { if( doc != null ) { doc.close(); } } } }