Kettle8.2修复作业或者转换重命名功能

kettle版本:8.2.0.0-311

问题描述:创建一个转换或者作业,命名为A并保存到资源库中,打开A,在探索资源库面板将A重命名为B,再打开B,这时Spoon面板会出现A与B两个。实际为一个转换或者作业。

原因分析:

1、分析重命名代码的具体实现步骤,代码入口:browseController.renameContent()

Kettle8.2修复作业或者转换重命名功能_第1张图片

Kettle8.2修复作业或者转换重命名功能_第2张图片

分析以上代码,重命名操作只是修改了数据库和当前面板的缓存数据,并未对Spoon面板进程操作。

2、再来看看打开操作的代码,此处就是为什么会打开两个转换或者作业的原因,代码入口:browseController.openContent()

Kettle8.2修复作业或者转换重命名功能_第3张图片

注意到红圈内代码,打开操作有一个回调函数,该回调接口名为RepositoryExplorerCallback,实际实现在Spoon.exploreRepository()方法中,我们可以看到,该接口只有一个open方法,并没有rename或者其他操作(例如:我们实际应用项目中添加了发布操作),我们再看一下open的具体实现代码(以trans为例,job类似)。

从Spoon.exploreRepository()向下走,进入loadObjectFromRepository方法,此处会获取一个TransMeta,注意此处获取TransMeta的途径是经过objectId获取的。

Kettle8.2修复作业或者转换重命名功能_第4张图片

接着进入SpoonTransformationDelegate类的addTransGraph()方法,此处有两个缓存,spoon.delegates.tabs中存储的为TabMapEntry对象(一个对象对应一个展示面板),transformationMap存储已经打开的转换TransMeta对象,通过addTransformation方法进行判断(判断方法实际为转换名称),如果该转换不存在,在两个缓存对象中添加响应的数据,spoon.enableMenus()刷新之后,spoon面板就能展开此模型。

Kettle8.2修复作业或者转换重命名功能_第5张图片

3、通过上面的重名操作步骤和打开操作步骤,可以分析出原因。重命名操作之后,并未对spoon.delegates.tabs和transformationMap缓存对象进行操作,当再次打开这转换的时候,又重新查询了该转换,名称为新名称,在进行addTransformation判断时候,以新名称获取缓存对象为空,所以又添加进一个转换,导致Spoon面板同时打开两个转换(实则为一个转换)。

处理方法:在RepositoryExplorerCallback中添加重命名接口,在重命名成功之后,刷新Spoon的两个缓存对象即可。

Kettle8.2修复作业或者转换重命名功能_第6张图片

 

你可能感兴趣的:(Kettle,kettle8.2,重命名,交互,spoon)