mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-25 21:23:53 +01:00 
			
		
		
		
	[ci] Add automated memory impact analysis for pull requests (#11242)
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: pre-commit-ci-lite[bot] <117423508+pre-commit-ci-lite[bot]@users.noreply.github.com>
This commit is contained in:
		
							
								
								
									
										27
									
								
								script/templates/ci_memory_impact_comment_template.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								script/templates/ci_memory_impact_comment_template.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| {{ comment_marker }} | ||||
| ## Memory Impact Analysis | ||||
|  | ||||
| **Components:** {{ components_str }} | ||||
| **Platform:** `{{ platform }}` | ||||
|  | ||||
| | Metric | Target Branch | This PR | Change | | ||||
| |--------|--------------|---------|--------| | ||||
| | **RAM** | {{ target_ram }} | {{ pr_ram }} | {{ ram_change }} | | ||||
| | **Flash** | {{ target_flash }} | {{ pr_flash }} | {{ flash_change }} | | ||||
| {% if component_breakdown %} | ||||
| {{ component_breakdown }} | ||||
| {% endif %} | ||||
| {% if symbol_changes %} | ||||
| {{ symbol_changes }} | ||||
| {% endif %} | ||||
| {%- if target_cache_hit %} | ||||
|  | ||||
| > ⚡ Target branch analysis was loaded from cache (build skipped for faster CI). | ||||
| {%- endif %} | ||||
|  | ||||
| --- | ||||
| > **Note:** This analysis measures **static RAM and Flash usage** only (compile-time allocation). | ||||
| > **Dynamic memory (heap)** cannot be measured automatically. | ||||
| > **⚠️ You must test this PR on a real device** to measure free heap and ensure no runtime memory issues. | ||||
|  | ||||
| *This analysis runs automatically when components change. Memory usage is measured from {{ config_note }}.* | ||||
							
								
								
									
										15
									
								
								script/templates/ci_memory_impact_component_breakdown.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								script/templates/ci_memory_impact_component_breakdown.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
|  | ||||
| <details open> | ||||
| <summary>📊 Component Memory Breakdown</summary> | ||||
|  | ||||
| | Component | Target Flash | PR Flash | Change | | ||||
| |-----------|--------------|----------|--------| | ||||
| {% for comp, target_flash, pr_flash, delta in changed_components[:max_rows] -%} | ||||
| {% set threshold = component_change_threshold if comp.startswith("[esphome]") else none -%} | ||||
| | `{{ comp }}` | {{ target_flash|format_bytes }} | {{ pr_flash|format_bytes }} | {{ format_change(target_flash, pr_flash, threshold=threshold) }} | | ||||
| {% endfor -%} | ||||
| {% if changed_components|length > max_rows -%} | ||||
| | ... | ... | ... | *({{ changed_components|length - max_rows }} more components not shown)* | | ||||
| {% endif -%} | ||||
|  | ||||
| </details> | ||||
							
								
								
									
										8
									
								
								script/templates/ci_memory_impact_macros.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								script/templates/ci_memory_impact_macros.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| {#- Macro for formatting symbol names in tables -#} | ||||
| {%- macro format_symbol(symbol, max_length, truncate_length) -%} | ||||
| {%- if symbol|length <= max_length -%} | ||||
| `{{ symbol }}` | ||||
| {%- else -%} | ||||
| <details><summary><code>{{ symbol[:truncate_length] }}...</code></summary><code>{{ symbol }}</code></details> | ||||
| {%- endif -%} | ||||
| {%- endmacro -%} | ||||
							
								
								
									
										51
									
								
								script/templates/ci_memory_impact_symbol_changes.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								script/templates/ci_memory_impact_symbol_changes.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| {%- from 'ci_memory_impact_macros.j2' import format_symbol -%} | ||||
|  | ||||
| <details> | ||||
| <summary>🔍 Symbol-Level Changes (click to expand)</summary> | ||||
|  | ||||
| {% if changed_symbols %} | ||||
|  | ||||
| ### Changed Symbols | ||||
|  | ||||
| | Symbol | Target Size | PR Size | Change | | ||||
| |--------|-------------|---------|--------| | ||||
| {% for symbol, target_size, pr_size, delta in changed_symbols[:max_changed_rows] -%} | ||||
| | {{ format_symbol(symbol, symbol_max_length, symbol_truncate_length) }} | {{ target_size|format_bytes }} | {{ pr_size|format_bytes }} | {{ format_change(target_size, pr_size) }} | | ||||
| {% endfor -%} | ||||
| {% if changed_symbols|length > max_changed_rows -%} | ||||
| | ... | ... | ... | *({{ changed_symbols|length - max_changed_rows }} more changed symbols not shown)* | | ||||
| {% endif -%} | ||||
|  | ||||
| {% endif %} | ||||
| {% if new_symbols %} | ||||
|  | ||||
| ### New Symbols (top {{ max_new_rows }}) | ||||
|  | ||||
| | Symbol | Size | | ||||
| |--------|------| | ||||
| {% for symbol, size in new_symbols[:max_new_rows] -%} | ||||
| | {{ format_symbol(symbol, symbol_max_length, symbol_truncate_length) }} | {{ size|format_bytes }} | | ||||
| {% endfor -%} | ||||
| {% if new_symbols|length > max_new_rows -%} | ||||
| {% set total_new_size = new_symbols|sum(attribute=1) -%} | ||||
| | *{{ new_symbols|length - max_new_rows }} more new symbols...* | *Total: {{ total_new_size|format_bytes }}* | | ||||
| {% endif -%} | ||||
|  | ||||
| {% endif %} | ||||
| {% if removed_symbols %} | ||||
|  | ||||
| ### Removed Symbols (top {{ max_removed_rows }}) | ||||
|  | ||||
| | Symbol | Size | | ||||
| |--------|------| | ||||
| {% for symbol, size in removed_symbols[:max_removed_rows] -%} | ||||
| | {{ format_symbol(symbol, symbol_max_length, symbol_truncate_length) }} | {{ size|format_bytes }} | | ||||
| {% endfor -%} | ||||
| {% if removed_symbols|length > max_removed_rows -%} | ||||
| {% set total_removed_size = removed_symbols|sum(attribute=1) -%} | ||||
| | *{{ removed_symbols|length - max_removed_rows }} more removed symbols...* | *Total: {{ total_removed_size|format_bytes }}* | | ||||
| {% endif -%} | ||||
|  | ||||
| {% endif %} | ||||
|  | ||||
| </details> | ||||
		Reference in New Issue
	
	Block a user