Skip to content

Commit

Permalink
collect warning messages and filter out duplicated
Browse files Browse the repository at this point in the history
  • Loading branch information
mirpedrol committed Dec 21, 2023
1 parent 96ae3c4 commit aa3248c
Showing 1 changed file with 15 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,12 @@ import java.util.concurrent.ConcurrentHashMap
@PackageScope(PackageScopeTarget.FIELDS)
class CO2FootprintFactory implements TraceObserverFactory {

// Handle logging messages
private List<String> warnings = []

boolean hasWarnings() { warnings.size() > 0 }
List<String> getWarnings() { warnings }

private CO2FootprintConfig config
private Session session
final private Map<TaskId,CO2Record> co2eRecords = new ConcurrentHashMap<>()
Expand Down Expand Up @@ -115,7 +121,7 @@ class CO2FootprintFactory implements TraceObserverFactory {
}
c++
}
log.warn "Could not find CPU model ${cpu_model} in given TDP data. Using default CPU power draw value!"
warnings << "Could not find CPU model ${cpu_model} in given TDP data. Using default CPU power draw value!".toString()
return cpuData['default']
}

Expand Down Expand Up @@ -144,7 +150,7 @@ class CO2FootprintFactory implements TraceObserverFactory {
// TODO if requested more than used, this is not taken into account, right?
Double cpu_usage = trace.get('%cpu') as Double
if ( cpu_usage == null ) {
log.debug "cpu_usage is null"
warnings << "cpu_usage is null"
// TODO why is value null, because task was finished so fast that it was not captured? Or are there other reasons?
// Assuming requested cpus were used with 100%
cpu_usage = nc * 100
Expand Down Expand Up @@ -343,6 +349,13 @@ class CO2FootprintFactory implements TraceObserverFactory {
current.values().each { taskId, record -> co2eFile.println("${taskId}\t-") }
co2eFile.flush()
co2eFile.close()

// Log warnings
if( hasWarnings() ) {
def filteredWarnings = getWarnings().unique( false )
def msg = "\033[0;33mThe following warnings were generated during the execution of the workflow:\n\t- " + filteredWarnings.join('\n\t- ').trim() + "\n\033[0m"
log.warn(msg)
}
}

@Override
Expand Down

0 comments on commit aa3248c

Please sign in to comment.