YARN-410. Fixed RM UI so that the new lines diagnostics for a failed app on the per-application page are translated to html line breaks. Contributed by Omkar Vinit Joshi.
svn merge --ignore-ancestry -c 1451808 ../../trunk/ git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/branches/branch-2@1451809 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ef48c24a74
commit
cd1aca1c82
|
@ -14,6 +14,10 @@ Release 2.0.4-beta - UNRELEASED
|
||||||
YARN-380. Fix yarn node -status output to be better readable. (Omkar Vinit
|
YARN-380. Fix yarn node -status output to be better readable. (Omkar Vinit
|
||||||
Joshi via vinodkv)
|
Joshi via vinodkv)
|
||||||
|
|
||||||
|
YARN-410. Fixed RM UI so that the new lines diagnostics for a failed app on
|
||||||
|
the per-application page are translated to html line breaks. (Omkar Vinit
|
||||||
|
Joshi via vinodkv)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
BUG FIXES
|
BUG FIXES
|
||||||
|
|
|
@ -20,7 +20,11 @@ package org.apache.hadoop.yarn.webapp.view;
|
||||||
|
|
||||||
import org.apache.hadoop.yarn.webapp.ResponseInfo;
|
import org.apache.hadoop.yarn.webapp.ResponseInfo;
|
||||||
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet;
|
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet;
|
||||||
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet.*;
|
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet.DIV;
|
||||||
|
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet.TABLE;
|
||||||
|
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet.TD;
|
||||||
|
import org.apache.hadoop.yarn.webapp.hamlet.Hamlet.TR;
|
||||||
|
|
||||||
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
|
|
||||||
|
@ -47,7 +51,19 @@ public class InfoBlock extends HtmlBlock {
|
||||||
String value = String.valueOf(item.value);
|
String value = String.valueOf(item.value);
|
||||||
if (item.url == null) {
|
if (item.url == null) {
|
||||||
if (!item.isRaw) {
|
if (!item.isRaw) {
|
||||||
tr.td(value);
|
TD<TR<TABLE<DIV<Hamlet>>>> td = tr.td();
|
||||||
|
if ( value.lastIndexOf('\n') > 0) {
|
||||||
|
String []lines = value.split("\n");
|
||||||
|
DIV<TD<TR<TABLE<DIV<Hamlet>>>>> singleLineDiv;
|
||||||
|
for ( String line :lines) {
|
||||||
|
singleLineDiv = td.div();
|
||||||
|
singleLineDiv._r(line);
|
||||||
|
singleLineDiv._();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
td._r(value);
|
||||||
|
}
|
||||||
|
td._();
|
||||||
} else {
|
} else {
|
||||||
tr.td()._r(value)._();
|
tr.td()._r(value)._();
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hadoop.yarn.webapp.view;
|
||||||
|
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import org.apache.hadoop.yarn.webapp.ResponseInfo;
|
||||||
|
import org.apache.hadoop.yarn.webapp.test.WebAppTests;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class TestInfoBlock {
|
||||||
|
|
||||||
|
public static StringWriter sw;
|
||||||
|
|
||||||
|
public static PrintWriter pw;
|
||||||
|
|
||||||
|
public static class MultilineInfoBlock extends InfoBlock{
|
||||||
|
|
||||||
|
static ResponseInfo resInfo;
|
||||||
|
|
||||||
|
static {
|
||||||
|
resInfo = new ResponseInfo();
|
||||||
|
resInfo._("Single_line_value", "This is one line.");
|
||||||
|
resInfo._("Multiple_line_value", "This is first line.\nThis is second line.");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PrintWriter writer() {
|
||||||
|
return TestInfoBlock.pw;
|
||||||
|
}
|
||||||
|
|
||||||
|
MultilineInfoBlock(ResponseInfo info) {
|
||||||
|
super(resInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
public MultilineInfoBlock() {
|
||||||
|
super(resInfo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setup() {
|
||||||
|
sw = new StringWriter();
|
||||||
|
pw = new PrintWriter(sw);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(timeout=60000L)
|
||||||
|
public void testMultilineInfoBlock() throws Exception{
|
||||||
|
|
||||||
|
WebAppTests.testBlock(MultilineInfoBlock.class);
|
||||||
|
TestInfoBlock.pw.flush();
|
||||||
|
String output = TestInfoBlock.sw.toString().replaceAll(" +", " ");
|
||||||
|
String expectedSinglelineData = "<tr class=\"odd\">\n"
|
||||||
|
+ " <th>\n Single_line_value\n <td>\n This is one line.\n";
|
||||||
|
String expectedMultilineData = "<tr class=\"even\">\n"
|
||||||
|
+ " <th>\n Multiple_line_value\n <td>\n <div>\n"
|
||||||
|
+ " This is first line.\n </div>\n <div>\n"
|
||||||
|
+ " This is second line.\n </div>\n";
|
||||||
|
assertTrue(output.contains(expectedSinglelineData) && output.contains(expectedMultilineData));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue