繁体   English   中英

如何检索Java Web应用程序的更改列表?

[英]How can I retrieve a list of changes for my Java web app?

我有一个Spring Boot应用程序,我想有一个页面,其中列出了最近的内部版本号及其包含的更改列表。 我使用了Rally,git和Jenkins,但是没有手动更新HTML或db表,我想知道是否没有一种更自动化的方法来检索此信息?

任何人都可以在应用程序中分享其在网页上列出此信息的方法吗?

如果您在Jenkins中将/api/json?pretty=true附加到作业URL的末尾,您会看到作业本身的JSON输出,这可能会导致您获得最新的内部版本号。 此外,这会将您带到最新版本的URL,(再次附加/api/json?pretty=true )可以将您带到变更集的JSON列表(以及相应的提交消息)。

您甚至可能不需要利用Rally! :-)

您可以使用JSON封送和RestTemplate Spring类从Spring应用程序中使用该JSON。

您可以通过使用Git连接器Jenkins插件 (只要两者都指向同一存储库)来跟踪从git提交到关联的CA AgileCentral(Rally)工件的成功和失败的Jenkins构建,只要两者都指向同一存储库,并且git中的提交提到相关工件的FormattedID。

这是一个基于Rally API Toolkit For Java的Java示例。 无论选择什么工具包,语言等等,都是通过底层WS API对象模型提供对这些数据的访问。 我通过CreationDate限制了构建查询。 在Build对象的其他字段中,我获取Changesets集合。 该集合的每个元素都是对Changeset对象的引用。 Git连接器在CA Agile Central(Rally)中创建更改集对象。 每个Changeset对象都有Artfacts集合字段和Changes集合字段。 Artifacts集合的每个元素都是对Rally工件的引用,例如用户故事,缺陷。 通过在每个Change对象上获取PathAndFilename,您将获得关联的源文件。 现在,我们可以将失败的构建跟踪到特定的提交,文件和用户故事。

这是下面的Java代码创建的控制台输出的屏幕截图。 最终,您可能希望以一种更具视觉吸引力的方式呈现数据。 该示例仅显示可以通过WS API跟踪构建和提交到用户案例或缺陷。

通常需要单独的请求来混合WS API中的集合 由于Build和Cangesets数据可能很大,因此请按某些条件绑定这些查询,例如CreationDate将使其更快。

在此处输入图片说明

public class GetBuildData {

    public static void main(String[] args) throws Exception {

        String host = "https://rally1.rallydev.com";
        String apiKey = "_abc123"; 
        String applicationName = "NickM:GetBuildData";
        String workspaceRef = "/workspace/12345";
        String projectRef = "/project/1346";

        RallyRestApi restApi = null;
        try {
            String dateString = "2016-05-12";
            restApi = new RallyRestApi(new URI(host),apiKey);
            restApi.setApplicationName(applicationName);
            QueryRequest buildRequest = new QueryRequest("Build");
            buildRequest.setFetch(new Fetch("Status,Message,Start,Uri,Changesets"));
            buildRequest.setQueryFilter(new QueryFilter("CreationDate", ">", dateString));
            buildRequest.setWorkspace(workspaceRef);
            buildRequest.setProject(projectRef);
            QueryResponse buildResponse = restApi.query(buildRequest);
            for (int i=0; i<buildResponse.getTotalResultCount();i++){
                JsonObject buildObj = buildResponse.getResults().get(i).getAsJsonObject();
                System.out.println("Build Status: " + buildObj.get("Status") +
                        "\n Build Message: " + buildObj.get("Message") +
                        "\n Build Start:   " + buildObj.get("Start") +
                        "\n Build Uri:     " + buildObj.get("Uri"));
                JsonObject changesetsCollection = buildObj.get("Changesets").getAsJsonObject();
                QueryRequest changesetsRequest = new QueryRequest(changesetsCollection);
                changesetsRequest.setFetch(new Fetch("Artifacts","Changes", "Revision"));
                changesetsRequest.setLimit(1000);
                QueryResponse changesetsResponse = restApi.query(changesetsRequest);
                for (int j=0; j<changesetsResponse.getTotalResultCount();j++) {
                    JsonObject changesetObj = changesetsResponse.getResults().get(j).getAsJsonObject();
                    System.out.println("\nChangeset Revision: " + changesetObj.get("Revision"));
                    JsonObject artifactsCollection = changesetObj.get("Artifacts").getAsJsonObject();
                    QueryRequest artifactsRequest = new QueryRequest(artifactsCollection);
                    artifactsRequest.setFetch(new Fetch("FormattedID"));
                    QueryResponse artifactsResponse = restApi.query(artifactsRequest);
                    for (int k=0; k<artifactsResponse.getTotalResultCount();k++) {
                        JsonObject artifactObj = artifactsResponse.getResults().get(k).getAsJsonObject();
                        System.out.println("\nArtifact FormattedID: " + artifactObj.get("FormattedID"));
                    }
                    JsonObject changesCollection = changesetObj.get("Changes").getAsJsonObject();
                    QueryRequest changesRequest = new QueryRequest(changesCollection);
                    changesRequest.setWorkspace(workspaceRef);
                    changesRequest.setProject(projectRef);
                    changesRequest.setFetch(new Fetch("PathAndFilename"));
                    QueryResponse changesResponse = restApi.query(changesRequest);
                    for (int l=0; l<changesResponse.getTotalResultCount();l++) {
                        JsonObject changeObj = changesResponse.getResults().get(l).getAsJsonObject();
                        System.out.println("Change PathAndFilename: " + changeObj.get("PathAndFilename"));
                    }

                }
                System.out.println("--------------------------------");
            }
        } finally {
            if (restApi != null) {
                restApi.close();
            }
        }
    }
}

如果要在Agile Central(拉力赛)中显示构建数据,可以在自定义页面中部署AppSDK2.1 javascript应用程序。 这是一个快速的示例开始:

    <!DOCTYPE html>
<html>
<head>
    <title>Builds by Date</title>
    <script type="text/javascript" src="/apps/2.1/sdk.js"></script>
    <script type="text/javascript">
        Rally.onReady(function () {
                Ext.define('CustomApp', {
    extend: 'Rally.app.App',
    componentCls: 'app',
    launch: function() {
        this.add({
            xtype: 'component',
            itemId: 'datepick',
            html: 'pick a date:',
            width: 100,
            margin: 10
        },
        {
            xtype: 'rallydatepicker',
            showToday: false,
            contentEl: Ext.ComponentQuery.query('#datepick')[0],
            margin: 10,
            handler: function(picker, date) {
                this.getBuilds(date);
            },
            scope:this
        },
        {
            xtype: 'container',
            itemId: 'gridContainer'
        });
    },
    getBuilds:function(date){
        var formattedDate = Rally.util.DateTime.formatWithDefault(date, this.getContext());
        Ext.ComponentQuery.query('#datepick')[0].update((formattedDate) + '<br /> selected');
        if (this.down('rallygrid')) {
            Ext.ComponentQuery.query('#gridContainer')[0].remove(Ext.ComponentQuery.query('#buildsGrid')[0], true);
        }
        this.down('#gridContainer').add({
            xtype: 'rallygrid',
            itemId: 'buildsGrid',
            columnCfgs: [
                'Status',
                'Message',
                'Start',
                'Uri',
                'Changesets'
            ],
            storeConfig: {
                model: 'build',
                filters:[
                    {
                        property: 'CreationDate',
                        operator: '>=',
                        value: Rally.util.DateTime.toIsoString(date,true)
                    }
                ]
            }
        });
    }
});
            Rally.launchApp('CustomApp', {
                name:"Builds by Date",
                parentRepos:""
            });
        });
    </script>
    <style type="text/css">
        .app {
  /* Add app styles here */
}
    </style>
</head>
<body>
</body>
</html>

在此处输入图片说明

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM