mirror of
https://github.com/eclipse-cdt/cdt
synced 2025-04-29 19:45:01 +02:00
bug 348884: ConcurrentModificationException in StorableCdtVariables
This commit is contained in:
parent
5a964614c4
commit
582b358f0f
3 changed files with 94 additions and 6 deletions
|
@ -0,0 +1,74 @@
|
|||
/*******************************************************************************
|
||||
* Copyright (c) 2012 Veaceslav Bacu (Freescale Semiconductor Inc.) and others.
|
||||
* All rights reserved. This program and the accompanying materials
|
||||
* are made available under the terms of the Eclipse Public License v1.0
|
||||
* which accompanies this distribution, and is available at
|
||||
* http://www.eclipse.org/legal/epl-v10.html
|
||||
*
|
||||
* Contributors:
|
||||
* Veaceslav Bacu (Freescale Semiconductor Inc.) - initial API and implementation (bug 348884)
|
||||
*
|
||||
*******************************************************************************/
|
||||
|
||||
package org.eclipse.cdt.utils;
|
||||
|
||||
import java.util.ConcurrentModificationException;
|
||||
|
||||
import junit.framework.Test;
|
||||
import junit.framework.TestCase;
|
||||
import junit.framework.TestSuite;
|
||||
|
||||
import org.eclipse.cdt.core.CCorePlugin;
|
||||
import org.eclipse.cdt.core.cdtvariables.ICdtVariable;
|
||||
import org.eclipse.cdt.core.cdtvariables.IUserVarSupplier;
|
||||
import org.eclipse.cdt.core.model.CoreModel;
|
||||
import org.eclipse.cdt.core.settings.model.ICConfigurationDescription;
|
||||
import org.eclipse.cdt.core.settings.model.ICProjectDescription;
|
||||
import org.eclipse.cdt.core.testplugin.ResourceHelper;
|
||||
import org.eclipse.cdt.internal.core.cdtvariables.StorableCdtVariable;
|
||||
import org.eclipse.core.resources.IProject;
|
||||
|
||||
public class StorableCdtVariablesTest extends TestCase {
|
||||
|
||||
public static Test suite() {
|
||||
return new TestSuite(StorableCdtVariablesTest.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void tearDown() throws Exception {
|
||||
ResourceHelper.cleanUp();
|
||||
}
|
||||
|
||||
/*
|
||||
* Unit test for Bugzilla #348884
|
||||
*/
|
||||
public void testSetMacros() throws Exception {
|
||||
IProject project = ResourceHelper.createCDTProjectWithConfig("projectWithUserVars"); //$NON-NLS-1$
|
||||
|
||||
ICProjectDescription prjDesc = CoreModel.getDefault().getProjectDescription(project);
|
||||
ICConfigurationDescription desc = prjDesc.getActiveConfiguration();
|
||||
|
||||
StorableCdtVariable varA1 = new StorableCdtVariable("A1", ICdtVariable.VALUE_TEXT, "a1"); //$NON-NLS-1$ //$NON-NLS-2$
|
||||
StorableCdtVariable varA2 = new StorableCdtVariable("A2", ICdtVariable.VALUE_TEXT, "a2"); //$NON-NLS-1$ //$NON-NLS-2$
|
||||
StorableCdtVariable varA3 = new StorableCdtVariable("A3", ICdtVariable.VALUE_TEXT, "a3"); //$NON-NLS-1$ //$NON-NLS-2$
|
||||
StorableCdtVariable varA4 = new StorableCdtVariable("A4", ICdtVariable.VALUE_TEXT, "a4"); //$NON-NLS-1$ //$NON-NLS-2$
|
||||
StorableCdtVariable varA5 = new StorableCdtVariable("A5", ICdtVariable.VALUE_TEXT, "a5"); //$NON-NLS-1$ //$NON-NLS-2$
|
||||
|
||||
IUserVarSupplier supplier = CCorePlugin.getUserVarSupplier();
|
||||
|
||||
try{
|
||||
supplier.setMacros(new ICdtVariable[]{varA1, varA2, varA3, varA4}, desc);
|
||||
}catch(Throwable e){
|
||||
fail("1.0 Cannot set macros"); //$NON-NLS-1$
|
||||
}
|
||||
|
||||
try{
|
||||
supplier.setMacros(new ICdtVariable[]{varA1, varA2, varA5}, desc);
|
||||
}catch(ConcurrentModificationException e){
|
||||
fail("1.1 Bugzilla #348884 unresolved"); //$NON-NLS-1$
|
||||
}catch(Exception e){
|
||||
fail("1.2 Cannot set macros"); //$NON-NLS-1$
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -36,6 +36,7 @@ import org.eclipse.cdt.utils.ByteUtilsTest;
|
|||
import org.eclipse.cdt.utils.CdtVariableResolverTest;
|
||||
import org.eclipse.cdt.utils.CommandLineUtilTest;
|
||||
import org.eclipse.cdt.utils.FindProgramLocationTest;
|
||||
import org.eclipse.cdt.utils.StorableCdtVariablesTest;
|
||||
import org.eclipse.cdt.utils.WeakHashSetTest;
|
||||
|
||||
/**
|
||||
|
@ -76,6 +77,7 @@ public class AutomatedIntegrationSuite extends TestSuite {
|
|||
suite.addTest(AllLanguageTests.suite());
|
||||
suite.addTest(RewriteTests.suite());
|
||||
suite.addTest(CdtVariableResolverTest.suite());
|
||||
suite.addTest(StorableCdtVariablesTest.suite());
|
||||
suite.addTest(CommandLineUtilTest.suite());
|
||||
suite.addTest(WeakHashSetTest.suite());
|
||||
suite.addTest(FindProgramLocationTest.suite());
|
||||
|
|
|
@ -12,7 +12,9 @@ package org.eclipse.cdt.internal.core.cdtvariables;
|
|||
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import org.eclipse.cdt.core.cdtvariables.CdtVariableException;
|
||||
import org.eclipse.cdt.core.cdtvariables.ICdtVariable;
|
||||
|
@ -183,14 +185,24 @@ public class StorableCdtVariables implements IStorableCdtVariables {
|
|||
deleteAll();
|
||||
else{
|
||||
if (getMap().size() != 0) {
|
||||
/*
|
||||
* Fix for Bugzilla #348884
|
||||
*/
|
||||
Set<String> existing = new HashSet<String>();
|
||||
Set<String> macroNames = new HashSet<String>();
|
||||
|
||||
for (ICdtVariable m : getMap().values()){
|
||||
int i;
|
||||
for(i = 0 ; i < macros.length; i++){
|
||||
if(m.getName().equals(macros[i].getName()))
|
||||
break;
|
||||
existing.add(m.getName());
|
||||
}
|
||||
|
||||
for (ICdtVariable m : macros){
|
||||
macroNames.add(m.getName());
|
||||
}
|
||||
|
||||
for (String name : existing){
|
||||
if (!macroNames.contains(name)){
|
||||
deleteMacro(name);
|
||||
}
|
||||
if(i == macros.length)
|
||||
deleteMacro(m.getName());
|
||||
}
|
||||
}
|
||||
createMacros(macros);
|
||||
|
|
Loading…
Add table
Reference in a new issue