From e1af2f331051a08ea1f5dee369847340be85ad5e Mon Sep 17 00:00:00 2001 From: Julien Lancelot Date: Tue, 24 Dec 2013 10:10:55 +0100 Subject: SONAR-4535 Update rule now use Java facade --- .../src/main/java/org/sonar/core/rule/RuleDao.java | 20 +++++++++++++++++++- .../main/java/org/sonar/core/rule/RuleMapper.java | 2 ++ .../resources/org/sonar/core/rule/RuleMapper.xml | 15 ++++++++++++--- .../test/java/org/sonar/core/rule/RuleDaoTest.java | 16 ++++++++++++++++ .../rule/RuleDaoTest/update_parameter-result.xml | 3 +++ .../sonar/core/rule/RuleDaoTest/update_parameter.xml | 3 +++ 6 files changed, 55 insertions(+), 4 deletions(-) create mode 100644 sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter-result.xml create mode 100644 sonar-core/src/test/resources/org/sonar/core/rule/RuleDaoTest/update_parameter.xml (limited to 'sonar-core') 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 @@ - 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} @@ -105,10 +105,19 @@ - + INSERT INTO rules_parameters (rule_id, name, param_type, default_value, description) VALUES (#{ruleId}, #{name}, #{type}, #{defaultValue}, #{description}) + + UPDATE rules_parameters SET + name=#{name}, + param_type=#{type}, + default_value=#{defaultValue}, + description=#{description} + WHERE id=#{id} + + 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 @@ + + + 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 @@ + + + -- cgit v1.2.3