diff options
Diffstat (limited to 'sonar-core')
6 files changed, 55 insertions, 4 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/rule/RuleDao.java b/sonar-core/src/main/java/org/sonar/core/rule/RuleDao.java index 482835a57b6..922efb2c782 100644 --- a/sonar-core/src/main/java/org/sonar/core/rule/RuleDao.java +++ b/sonar-core/src/main/java/org/sonar/core/rule/RuleDao.java @@ -72,10 +72,14 @@ public class RuleDao implements BatchComponent, ServerComponent { } } + public void update(RuleDto rule, SqlSession session) { + getMapper(session).update(rule); + } + public void update(RuleDto rule) { SqlSession session = mybatis.openSession(); try { - getMapper(session).update(rule); + update(rule, session); session.commit(); } finally { MyBatis.closeQuietly(session); @@ -144,6 +148,20 @@ public class RuleDao implements BatchComponent, ServerComponent { } } + public void update(RuleParamDto param, SqlSession session) { + getMapper(session).updateParameter(param); + } + + public void update(RuleParamDto param) { + SqlSession session = mybatis.openSession(); + try { + update(param, session); + session.commit(); + } finally { + MyBatis.closeQuietly(session); + } + } + @CheckForNull public RuleParamDto selectParamByRuleAndKey(Integer ruleId, String key, SqlSession session) { return getMapper(session).selectParamByRuleAndKey(ruleId, key); diff --git a/sonar-core/src/main/java/org/sonar/core/rule/RuleMapper.java b/sonar-core/src/main/java/org/sonar/core/rule/RuleMapper.java index 9b2698d9453..8c340b33569 100644 --- a/sonar-core/src/main/java/org/sonar/core/rule/RuleMapper.java +++ b/sonar-core/src/main/java/org/sonar/core/rule/RuleMapper.java @@ -45,4 +45,6 @@ public interface RuleMapper { RuleParamDto selectParamByRuleAndKey(@Param("ruleId") Integer ruleId, @Param("key") String key); void insertParameter(RuleParamDto param); + + void updateParameter(RuleParamDto param); } diff --git a/sonar-core/src/main/resources/org/sonar/core/rule/RuleMapper.xml b/sonar-core/src/main/resources/org/sonar/core/rule/RuleMapper.xml index efa9a1f7290..95063093b9a 100644 --- a/sonar-core/src/main/resources/org/sonar/core/rule/RuleMapper.xml +++ b/sonar-core/src/main/resources/org/sonar/core/rule/RuleMapper.xml @@ -41,7 +41,7 @@ </select> <update id="update" parameterType="Rule"> - update rules set + UPDATE rules SET plugin_rule_key=#{ruleKey}, plugin_name=#{repositoryKey}, description=#{description}, @@ -57,7 +57,7 @@ note_user_login=#{noteUserLogin}, note_created_at=#{noteCreatedAt}, note_updated_at=#{noteUpdatedAt} - where id=#{id} + WHERE id=#{id} </update> <sql id="insertColumns"> @@ -105,10 +105,19 @@ </where> </select> - <insert id="insertParameter" parameterType="Rule" keyColumn="id" useGeneratedKeys="true" keyProperty="id"> + <insert id="insertParameter" parameterType="RuleParam" keyColumn="id" useGeneratedKeys="true" keyProperty="id"> INSERT INTO rules_parameters (rule_id, name, param_type, default_value, description) VALUES (#{ruleId}, #{name}, #{type}, #{defaultValue}, #{description}) </insert> + <update id="updateParameter" parameterType="RuleParam"> + UPDATE rules_parameters SET + name=#{name}, + param_type=#{type}, + default_value=#{defaultValue}, + description=#{description} + WHERE id=#{id} + </update> + </mapper> diff --git a/sonar-core/src/test/java/org/sonar/core/rule/RuleDaoTest.java b/sonar-core/src/test/java/org/sonar/core/rule/RuleDaoTest.java index f58e4790a15..43e0b9ce660 100644 --- a/sonar-core/src/test/java/org/sonar/core/rule/RuleDaoTest.java +++ b/sonar-core/src/test/java/org/sonar/core/rule/RuleDaoTest.java @@ -272,4 +272,20 @@ public class RuleDaoTest extends AbstractDaoTestCase { checkTables("insert_parameter", "rules_parameters"); } + + @Test + public void update_parameter() { + setupData("update_parameter"); + + RuleParamDto param = new RuleParamDto() + .setId(1) + .setName("format") + .setType("STRING") + .setDefaultValue("^[a-z]+(\\.[a-z][a-z0-9]*)*$") + .setDescription("Regular expression used to check the package names against."); + + dao.update(param); + + checkTables("update_parameter", "rules_parameters"); + } } diff --git a/sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter-result.xml b/sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter-result.xml new file mode 100644 index 00000000000..d61889441d9 --- /dev/null +++ b/sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter-result.xml @@ -0,0 +1,3 @@ +<dataset> + <rules_parameters id="1" rule_id="1" name="format" param_type="STRING" default_value="^[a-z]+(\.[a-z][a-z0-9]*)*$" description="Regular expression used to check the package names against."/> +</dataset> diff --git a/sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter.xml b/sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter.xml new file mode 100644 index 00000000000..5208b7a4a4c --- /dev/null +++ b/sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter.xml @@ -0,0 +1,3 @@ +<dataset> + <rules_parameters id="1" rule_id="1" name="max" param_type="INTEGER" default_value="30" description="My Parameter"/> +</dataset> |