mirror of
				https://gitea.invidious.io/iv-org/shard-ameba.git
				synced 2024-08-15 00:53:29 +00:00 
			
		
		
		
	Update UselessAssign rule to report unreferenced type declarations
				
					
				
			This commit is contained in:
		
							parent
							
								
									4ad151e5e0
								
							
						
					
					
						commit
						9745637cf9
					
				
					 2 changed files with 44 additions and 4 deletions
				
			
		|  | @ -492,8 +492,8 @@ module Ameba::Rule::Lint | ||||||
|         subject.catch(s).should be_valid |         subject.catch(s).should be_valid | ||||||
|       end |       end | ||||||
| 
 | 
 | ||||||
|       it "doesn't report if type declaration assigned inside class" do |       it "reports if type declaration assigned inside class" do | ||||||
|         s = Source.new %( |         s = Source.new path: "source.cr", code: %( | ||||||
|           class A |           class A | ||||||
|             foo : String? = "foo" |             foo : String? = "foo" | ||||||
| 
 | 
 | ||||||
|  | @ -502,7 +502,11 @@ module Ameba::Rule::Lint | ||||||
|             end |             end | ||||||
|           end |           end | ||||||
|         ) |         ) | ||||||
|         subject.catch(s).should be_valid |         subject.catch(s).should_not be_valid | ||||||
|  | 
 | ||||||
|  |         issue = s.issues.first | ||||||
|  |         issue.location.to_s.should eq "source.cr:2:3" | ||||||
|  |         issue.message.should eq "Useless assignment to variable `foo`" | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  | @ -1068,6 +1072,43 @@ module Ameba::Rule::Lint | ||||||
|       subject.catch(s).should be_valid |       subject.catch(s).should be_valid | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  |     context "type declaration" do | ||||||
|  |       it "reports if it's not referenced at a top level" do | ||||||
|  |         s = Source.new %( | ||||||
|  |           a : String? | ||||||
|  |         ) | ||||||
|  |         subject.catch(s).should_not be_valid | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       it "reports if it's not referenced in a method" do | ||||||
|  |         s = Source.new %( | ||||||
|  |           def foo | ||||||
|  |             a : String? | ||||||
|  |           end | ||||||
|  |         ) | ||||||
|  |         subject.catch(s).should_not be_valid | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       it "reports if it's not referenced in a class" do | ||||||
|  |         s = Source.new %( | ||||||
|  |           class Foo | ||||||
|  |             a : String? | ||||||
|  |           end | ||||||
|  |         ) | ||||||
|  |         subject.catch(s).should_not be_valid | ||||||
|  |       end | ||||||
|  | 
 | ||||||
|  |       it "doesn't report if it's referenced" do | ||||||
|  |         s = Source.new %( | ||||||
|  |           def foo | ||||||
|  |             a : String? | ||||||
|  |             a | ||||||
|  |           end | ||||||
|  |         ) | ||||||
|  |         subject.catch(s).should be_valid | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|     context "uninitialized" do |     context "uninitialized" do | ||||||
|       it "reports if uninitialized assignment is not referenced at a top level" do |       it "reports if uninitialized assignment is not referenced at a top level" do | ||||||
|         s = Source.new %( |         s = Source.new %( | ||||||
|  |  | ||||||
|  | @ -39,7 +39,6 @@ module Ameba::Rule::Lint | ||||||
|     def test(source, node, scope : AST::Scope) |     def test(source, node, scope : AST::Scope) | ||||||
|       scope.variables.each do |var| |       scope.variables.each do |var| | ||||||
|         next if var.ignored? || var.used_in_macro? || var.captured_by_block? |         next if var.ignored? || var.used_in_macro? || var.captured_by_block? | ||||||
|         next if scope.assigns_type_dec?(var.name) |  | ||||||
| 
 | 
 | ||||||
|         var.assignments.each do |assign| |         var.assignments.each do |assign| | ||||||
|           next if assign.referenced? |           next if assign.referenced? | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue